OpCodes.Unbox_Any 字段
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
将指令中指定的类型的装箱表示形式转换为其未装箱窗体。
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
字段值
注解
下表列出了指令的十六进制和Microsoft中间语言(MSIL)程序集格式,以及简短的参考摘要:
| 格式 | 程序集格式 | 描述 |
|---|---|---|
A5 <T> |
unbox.any typeTok |
从 obj中提取数据,其装箱表示形式。 |
堆栈过渡行为按顺序排列,为:
对象引用
obj推送到堆栈上。对象引用从堆栈弹出并取消装箱到指令中指定的类型。
生成的对象引用或值类型被推送到堆栈上。
应用于值类型的装箱形式时,unbox.any 指令提取 obj(类型为 O)中包含的值,因此等效于 unbox 后跟 ldobj。
应用于引用类型时,unbox.any 指令的效果与 castclasstypeTok相同。
如果操作数 typeTok 是泛型类型参数,则运行时行为由为该泛型类型参数指定的类型确定。
如果 obj 不是装箱类型,则会引发 InvalidCastException。
如果 obj 为 null 引用,则会引发 NullReferenceException。
以下 Emit 方法重载可以使用 unbox.any 操作码: