OpCodes.Conv_U2 字段

定义

将位于计算堆栈顶部的值转换为 unsigned int16,然后将其扩展为 int32

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

字段值

注解

下表列出了指令的十六进制和 Microsoft 中间语言 (MSIL) 程序集格式,以及简短的参考摘要:

格式 程序集格式 说明
D1 conv.u2 int16转换为 ,在int32堆栈上推送。

堆栈过渡行为(按顺序排列)为:

  1. value 被推送到堆栈上。

  2. value 从堆栈中弹出,并尝试转换操作。

  3. 如果转换成功,则生成的值将推送到堆栈上。

conv.u2 opcode 将value堆栈顶部的 转换为操作码中指定的类型,并将转换后的值保留在堆栈顶部。 当小于 4 字节 int32 的整数值加载到评估堆栈 (时,除非 conv.i 使用 或 conv.u ,在这种情况下,结果也会 native int) 。 浮点值将转换为 F 类型。

从浮点数转换为整数值会将数字截断为零。 从 float64 转换为 float32时,精度可能会丢失。 如果 value 太大而无法容纳 , float32 (F)则正无穷大 (为 value 正) 或负无穷大 (如果 value 为负) 返回。 如果在将一个整数类型转换为另一个整数类型时发生溢出,则会截断高阶位。 如果结果小于 , int32则值将进行符号扩展以填充槽。

如果发生溢出,将浮点类型转换为整数,则返回的值未指定。

使用此字段时不会引发异常。 有关当结果类型无法正确表示结果值时将引发异常的等效指令,请参阅 Conv_Ovf_I2Conv_Ovf_I2_Un

以下 Emit 方法重载可以使用 conv.u2 opcode:

适用于