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
指令提取) 类型的 O
(中包含的obj
值,因此等效于 unbox
后跟 ldobj
。
应用于引用类型时, unbox.any
指令的效果 castclass
typeTok
与 相同。
如果操作数 typeTok
是泛型类型参数,则运行时行为由为该泛型类型参数指定的类型确定。
InvalidCastException 如果 obj
不是装箱类型,则引发 。
NullReferenceException 如果 obj
是 null 引用,则引发 。
以下 Emit 方法重载可以使用 unbox.any
opcode:
适用于
反馈
https://aka.ms/ContentUserFeedback。
即将发布:在整个 2024 年,我们将逐步淘汰作为内容反馈机制的“GitHub 问题”,并将其取代为新的反馈系统。 有关详细信息,请参阅:提交和查看相关反馈