Поделиться через


OpCodes.Ldfld Поле

Определение

Выполняет поиск значения поля в объекте, ссылка на который находится в стеке вычислений.

public: static initonly System::Reflection::Emit::OpCode Ldfld;
public static readonly System.Reflection.Emit.OpCode Ldfld;
 staticval mutable Ldfld : System.Reflection.Emit.OpCode
Public Shared ReadOnly Ldfld As OpCode 

Значение поля

Комментарии

В следующей таблице приведен шестнадцатеричный формат инструкции и формат сборки msil, а также краткий обзор:

Формат Формат сборки Описание
7B <T> ldfld field Помещает значение поля в указанном объекте в стек.

Переходный режим стека в последовательном порядке:

  1. Ссылка на объект (или указатель) помещается в стек.

  2. Ссылка на объект (или указатель) извлекается из стека; найдено значение указанного поля в объекте .

  3. Значение, хранящееся в поле , помещается в стек.

Инструкция ldfld передает значение поля, расположенного в объекте, в стек. Объект должен находиться в стеке как ссылка на объект (тип O), управляемый указатель (тип &), неуправляемый указатель (тип native int), временный указатель (тип *) или экземпляр типа значения. Использование неуправляемого указателя не допускается в проверяемом коде. Поле объекта задается маркером метаданных, который должен ссылаться на элемент поля. Тип возвращаемого значения совпадает с типом, связанным с полем. Поле может быть полем экземпляра (в этом случае объект не должен быть пустой ссылкой) или статическим полем.

Инструкции ldfld могут предшествовать либо префиксы и Volatile , Unaligned либо оба.

NullReferenceException возникает, если объект имеет значение NULL, а поле не является статическим.

MissingFieldException возникает, если указанное поле не найдено в метаданных. Обычно это проверяется при преобразовании инструкций MSIL в машинный код, а не во время выполнения.

Следующая Emit перегрузка ldfld метода может использовать код операции:

Применяется к