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)程序集格式,以及简短的参考摘要:
| Format | 程序集格式 | Description |
|---|---|---|
A5 <T> |
unbox.any typeTok |
从 obj其装箱表示形式中提取数据。 |
堆栈过渡行为按顺序排列,为:
对象引用
obj被推送到堆栈上。对象引用从堆栈弹出并取消装箱到指令中指定的类型。
生成的对象引用或值类型被推送到堆栈上。
当应用于值类型的装箱形式时,指令unbox.any将提取包含在 (of typeobj) 中的O值,因此等效于unbox后跟ldobj。
应用于引用类型时,指令 unbox.any 的效果 castclasstypeTok与 .
如果操作数 typeTok 是泛型类型参数,则运行时行为由为该泛型类型参数指定的类型确定。
InvalidCastException 如果 obj 不是装箱类型,则引发 。
NullReferenceException 如果 obj 为 null 引用,则引发 。
以下 Emit 方法重载可以使用 unbox.any 操作码: