OpCodes.Ldflda OpCodes.Ldflda OpCodes.Ldflda OpCodes.Ldflda Field


参照が現在評価スタック上にあるオブジェクト内のフィールドのアドレスを検索します。Finds the address of a field in the object whose reference is currently on the evaluation stack.

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



次の表は、命令の 16 進数と簡単なリファレンス概要と共に、Microsoft Intermediate Language (MSIL) アセンブリの形式を示します。The following table lists the instruction's hexadecimal and Microsoft Intermediate Language (MSIL) assembly format, along with a brief reference summary:

形式Format アセンブリの形式Assembly Format 説明Description
7C < T >7C < T > ldflda fieldldflda field アドレスをプッシュfieldスタックに指定されたオブジェクト。Pushes the address of field in a specified object onto the stack.

履歴の移行動作を順番には。The stack transitional behavior, in sequential order, is:

  1. オブジェクト参照 (またはポインター) は、スタックにプッシュされます。An object reference (or pointer) is pushed onto the stack.

  2. オブジェクト参照 (またはポインター) がスタックからポップされます。オブジェクトで指定されたフィールドのアドレスが見つかりました。The object reference (or pointer) is popped from the stack; the address of the specified field in the object is found.

  3. 指定したフィールドのアドレスは、スタックにプッシュされます。The address of the specified field is pushed onto the stack.

ldflda命令がスタックにオブジェクトにあるフィールドのアドレスをプッシュします。The ldflda instruction pushes the address of a field located in an object onto the stack. オブジェクトがオブジェクト参照としてスタック上に存在する必要があります (型O)、マネージ ポインター (型&)、アンマネージ ポインター (型native int)、一時的なポインター (型*)、または値型のインスタンス。The object must be on the stack as an object reference (type O), a managed pointer (type &), an unmanaged pointer (type native int), a transient pointer (type *), or an instance of a value type. 検証可能なコードでは、アンマネージ ポインターは使用できません。The use of an unmanaged pointer is not permitted in verifiable code. オブジェクトのフィールドは、フィールドのメンバーを参照する必要があるメタデータ トークンによって指定されます。The object's field is specified by a metadata token that must refer to a field member.

によって返される値ldfldaマネージ ポインター (型&) オブジェクトをアンマネージ ポインターとしてスタックにプッシュすると、しない限り、場合、戻り値のアドレスもアンマネージ ポインター (型native int)。The value returned by ldflda is a managed pointer (type &) unless the object is pushed onto the stack as an unmanaged pointer, in which case the return address is also an unmanaged pointer (type native int).

ldflda命令の前に、いずれかまたは両方のUnalignedVolatileプレフィックス。The ldflda instruction can be preceded by either or both of the Unaligned and Volatile prefixes.

InvalidOperationException アクセス元のアプリケーション ドメイン内のオブジェクトがない場合にスローされます。InvalidOperationException is thrown if the object is not within the application domain from which it is being accessed. アクセスするアプリケーション ドメイン内でないフィールドのアドレスを読み込むことができません。The address of a field that is not inside the accessing application domain cannot be loaded.

NullReferenceException オブジェクトが null とフィールドが静的でない場合にスローされます。NullReferenceException is thrown if the object is null and the field is not static.

MissingFieldException メタデータで指定されたフィールドが見つからない場合にスローされます。MissingFieldException is thrown if the specified field is not found in the metadata. これは、通常、Microsoft 中間言語 (MSIL) 命令が実行時ではなく、ネイティブ コードに変換する場合にチェックします。This is typically checked when Microsoft Intermediate Language (MSIL) instructions are converted to native code, not at run time.

Emitメソッドのオーバー ロードを使用できる、 ldflda opcode:The following Emit method overload can use the ldflda opcode:

  • ILGenerator.Emit (オペコード、FieldInfo)ILGenerator.Emit(OpCode, FieldInfo)