OpCodes.Unbox_Any OpCodes.Unbox_Any OpCodes.Unbox_Any OpCodes.Unbox_Any Field

定義

命令で指定された型のボックス化変換された形式を、ボックス化が解除された形式に変換します。Converts the boxed representation of a type specified in the instruction to its unboxed form.

public: static initonly System::Reflection::Emit::OpCode Unbox_Any;
public static readonly System.Reflection.Emit.OpCode Unbox_Any;
 staticval mutable Unbox_Any : System.Reflection.Emit.OpCode
Public Shared ReadOnly Unbox_Any 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
A5 < T >A5 < T > unbox.any typeTokunbox.any typeTok データの抽出obj、その表現をボックス化します。Extract the data from obj, its boxed representation.

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

  1. オブジェクト参照objがスタックにプッシュされます。An object reference obj is pushed onto the stack.

  2. オブジェクト参照がスタックからポップし、命令で指定された型にボックス化解除します。The object reference is popped from the stack and unboxed to the type specified in the instruction.

  3. 結果として得られるオブジェクトの参照または値の型は、スタックにプッシュされます。The resulting object reference or value type is pushed onto the stack.

値の型のボックス化された形式に適用すると、unbox.any命令に含まれる値を抽出しますobj(型のO) と同じためunbox続けてldobjします。When applied to the boxed form of a value type, the unbox.any instruction extracts the value contained within obj (of type O), and is therefore equivalent to unbox followed by ldobj.

参照型に適用すると、unbox.any命令と同じ効果を持つcastclass``typeTokします。When applied to a reference type, the unbox.any instruction has the same effect as castclass typeTok.

場合、オペランドtypeTokがジェネリック型パラメーターでは、実行時の動作は、そのジェネリック型パラメーターに指定された型によって決定されます。If the operand typeTok is a generic type parameter, then the runtime behavior is determined by the type that is specified for that generic type parameter.

InvalidCastException 場合にスローされるobjボックス化された型ではありません。InvalidCastException is thrown if obj is not a boxed type.

NullReferenceException 場合にスローされるobjは null 参照です。NullReferenceException is thrown if obj is a null reference.

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

  • ILGenerator.Emit(OpCode, Type)ILGenerator.Emit(OpCode, Type)

適用対象