Где узнать о VS магическом именах отладчика - PullRequest
103 голосов
/ 24 марта 2010

Если вы когда-либо использовали Reflector, вы, вероятно, заметили, что компилятор C # генерирует типы, методы, поля и локальные переменные, которые заслуживают «специального» отображения отладчиком. Например, локальные переменные, начинающиеся с 'CS $', не отображаются пользователю. Существуют другие специальные соглашения об именах для типов закрытия анонимных методов, полей поддержки автоматических свойств и т. Д.

Мой вопрос: где узнать об этих соглашениях об именах? Кто-нибудь знает о какой-то документации?

Моя цель - заставить PostSharp 2.0 использовать те же соглашения.

1 Ответ

202 голосов
/ 24 марта 2010

Это недокументированные детали реализации компилятора, которые могут быть изменены в любое время. (ОБНОВЛЕНИЕ: см. GeneratedNames.cs в источниках C # для текущих деталей; приведенное ниже описание несколько устарело.)

Однако, поскольку я хороший парень, вот некоторые из этих деталей:

Если у вас есть неиспользуемая локальная переменная, которую оптимизатор удаляет, мы все равно отправляем отладочную информацию для нее в PDB. Мы прикрепили суффикс __Deleted$ к таким переменным, чтобы отладчик знал, что они были в исходном коде, но не представлены в двоичном файле.

Временным переменным слотам, выделенным компилятором, присваиваются имена с шаблоном CS $ X $ Y, где X - это «временный вид», а Y - количество временно выделенных времен. Временные виды:

0 --> short lived temporaries
1 --> return value temporaries
2 --> temporaries generated for lock statements
3 --> temporaries generated for using statements
4 --> durable temporaries
5 --> the result of get enumerator in a foreach
6 --> the array storage in a foreach
7 --> the array index storage in a foreach.  

Временные типы от 8 до 264 являются дополнительными хранилищами индексов массивов для многомерных массивов.

Временные типы выше 264 используются для временных значений, включающих фиксированный оператор, фиксирующий строку.

Специальные сгенерированные компилятором имена генерируются для:

1 --> the iterator state ("state")
2 --> the value of current in an iterator ("current")
3 --> a saved parameter in an iterator
4 --> a hoisted 'this' in an iterator ("this")
5 --> a hoisted local in an iterator
6 --> the hoisted locals from an outer scope
7 --> a hoisted wrapped value ("wrap")
8 --> the closure class instance ("locals")
9 --> the cached delegate instance ("CachedAnonymousMethodDelegate")
a --> the iterator instance ("iterator")
b --> an anonymous method
c --> anonymous method closure class ("DisplayClass")
d --> iterator class
e --> fixed buffer struct ("FixedBuffer")
f --> anonymous type ("AnonymousType")
g --> initializer local ("initLocal")
h --> query expression temporary ("TransparentIdentifier")
i --> anonymous type field ("Field")
j --> anonymous type type parameter ("TPar")
k --> auto prop field ("BackingField")
l --> iterator thread id
m --> iterator finally ("Finally")
n --> fabricated method ("FabricatedMethod")
o --> dynamic container class ("SiteContainer")
p --> dynamic call site ("Site")
q --> dynamic delegate ("SiteDelegate")
r --> com ref call local ("ComRefCallLocal")
s --> lock taken local ("LockTaken")

Шаблон для генерирования магических имен: P<N>C__SI, где:

  • P - CS $ для кэшированных делегатов и экземпляров класса отображения, в противном случае пустое.
  • N - оригинальное имя, связанное с вещью, если есть
  • C - это символы от 1 до s, перечисленные выше
  • S - это описательный суффикс («текущий», «состояние» и т. Д.), Поэтому вам не нужно запоминать таблицу выше при чтении метаданных.
  • I - необязательный уникальный номер
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...