OpCodes.Conv_R_Un 字段

定义

将位于计算堆栈顶部的无符号整数值转换为 float32

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

字段值

注解

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

格式 程序集格式 说明
76 conv.r.un 将无符号整数转换为浮点,在堆栈上推送 F

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

  1. value 被推送到堆栈上。

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

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

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

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

如果发生溢出,将浮点类型转换为整数,则 result 返回的 未指定。 该 conv.r.un 操作从堆栈中获取一个整数,将其解释为无符号,并将其替换为一个浮点数来表示该整数: float32如果其宽度足以表示整数而不丢失精度,则为 ;否则 float64为 。

使用此字段时,不会引发异常。

以下 Emit 方法重载可以使用 conv.r.un 操作码:

适用于