Рейтинговые книги
Читем онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 342 343 344 345 346 347 348 349 350 ... 642

Роль директив CIL

Прежде всего, существует набор хорошо известных лексем CIL, которые используются для описания общей структуры сборки .NET Core. Такие лексемы называются директивами. Директивы CIL позволяют информировать компилятор CIL о том, каким образом определять пространства имен, типы и члены, которые будут заполнять сборку.

Синтаксически директивы представляются с применением префикса в виде точки (.), например, .namespace, .class, .publickeytoken, .override, .method, .assembly и т.д. Таким образом, если в файле с расширением *.il (общепринятое расширение для файлов кода CIL) указана одна директива .namespace и три директивы .class, то компилятор CIL сгенерирует сборку, в которой определено единственное пространство имен .NET Core, содержащее три класса .NET Core.

Роль атрибутов CIL

 Во многих случаях директивы CIL сами по себе недостаточно описательны для того, чтобы полностью выразить определение заданного типа .NET Core или члена типа. С учетом этого факта многие директивы CIL могут сопровождаться разнообразными атрибутами CIL, которые уточняют способ обработки директивы. Например, директива .class может быть снабжена атрибутом public (для установления видимости типа), атрибутом extends (для явного указания базового класса типа) и атрибутом implements (для перечисления набора интерфейсов, поддерживаемых данным типом).

На заметку! Не путайте атрибут .NET Core (см. главу 17) и атрибут CIL, которые являются двумя совершенно разными понятиями.

Роль кодов операций СIL

После того как сборка, пространство имен и набор типов .NET Core определены в терминах языка CIL с использованием различных директив и связанных атрибутов, остается только предоставить логику реализации для типов. Это работа кодов операций. В традициях других низкоуровневых языков программирования многие коды операций CIL обычно имеют непонятный и совершенно нечитабельный вид. Например, для загрузки в память переменной типа string применяется код операции, который вместо дружественного имени наподобие LoadString имеет имя ldstr.

Справедливости ради следует отметить, что некоторые коды операций CIL довольно естественно отображаются на свои аналоги в C# (например, box, unbox, throw и sizeof). Вы увидите, что коды операций CIL всегда используются внутри области реализации члена и в отличие от директив никогда не записываются с префиксом-точкой.

Разница между кодами операций и их мнемоническими эквивалентами в СIL

Как только что объяснялось, для реализации членов отдельно взятого типа применяются коды операций вроде ldstr. Однако такие лексемы, как ldstr, являются мнемоническими эквивалентами CIL фактических двоичных кодов операций CIL. Чтобы выяснить разницу, напишите следующий метод C# в проекте консольного приложения .NET Core по имени FirstSamples:

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

int Add(int x, int y)

{

  return x + y;

}

В терминах CIL действие сложения двух чисел выражается посредством кода операции 0X58. В том же духе вычитание двух чисел выражается с помощью кода операции 0X59, а действие по размещению нового объекта в управляемой куче записывается с использованием кода операции 0X73. С учетом описанной реальности "код CIL" , обрабатываемый JIT-компилятором, представляет собой не более чем порцию двоичных данных.

К счастью, для каждого двоичного кода операции CIL предусмотрен соответствующий мнемонический эквивалент. Например, вместо кода 0X58 может применяться мнемонический эквивалент add, вместо 0X59 — sub, а вместо 0X73 — newobj. С учетом такой разницы между кодами операций и их мнемоническими эквивалентами декомпиляторы CIL, подобные ildasm.exe, транслируют двоичные коды операций сборки в соответствующие им мнемонические эквиваленты CIL. Вот как ildasm.exe представит в CIL предыдущий метод Add(), написанный на языке C# (в зависимости от версии .NET Core вывод может отличаться):

.method assembly hidebysig static int32 Add(int32 x,int32 y) cil managed

{

  // Code size 9 (0x9)

  .maxstack 2

  .locals init ([0] int32 int32 V_0)

  IL_0000:  /* 00   |                  */ nop

  IL_0001:  /* 02   |                  */ ldarg.0

  IL_0002:  /* 03   |                  */ ldarg.1

  IL_0003:  /* 58   |                  */ add

  IL_0004:  /* 0A   |                  */ stloc.0

  IL_0005:  /* 2B   | 00               */ br.s       IL_0007

  IL_0007:  /* 06   |                  */ ldloc.0

  IL_0008:  /* 2A   |                  */ ret

} //end of method

Если вы не занимаетесь разработкой исключительно низкоуровневого программного обеспечения .NET Core (вроде специального управляемого компилятора), то иметь дело с числовыми двоичными кодами операций CIL никогда не придется. На практике когда программисты, использующие .NET Core, говорят о "кодах операций CIL", они имеют в виду набор дружественных строковых мнемонических эквивалентов (что и делается в настоящей книге), а не лежащие в основе числовые значения.

Заталкивание и выталкивание: основанная на стеке природа CIL

В языках .NET Core высокого уровня (таких как С#) предпринимается попытка насколько возможно скрыть из виду низкоуровневые детали CIL. Один из особенно хорошо скрываемых аспектов — тот факт, что CIL является языком программирования, основанным на использовании стека. Вспомните из исследования пространств имен коллекций (см. главу 10), что класс Stack<T> может применяться для помещения значения в стек, а также для извлечения самого верхнего значения из стека с целью последующего использования. Разумеется, программисты на языке CIL не работают с объектом типа Stack<T> для загрузки и выгрузки вычисляемых значений, но применяемый ими образ действий похож на заталкивание и выталкивание.

1 ... 342 343 344 345 346 347 348 349 350 ... 642
На этой странице вы можете бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю бесплатно.
Похожие на Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю книги

Оставить комментарий