Ldc.i4 num 和 ldc.i4.s num 的区别
近日开始除了看除了看《入门经典》外,还在看《你必须知道的.net》。在看到《你必须知道的.net》的第二部分--本质 的时候,他开始讲“IL”了,看了其中的送数据到堆栈中,用到了ldc.i4 num 和 ldc.i4.s num 。
初看不懂,就查了MSDN ,解释如下;
下表列出了指令的十六进制和 Microsoft 中间语言 (MSIL) 汇编格式,以及简短的参考摘要:
格式 |
汇编格式 |
说明 |
20 < int32 > |
ldc.i4 num |
将值 num 推送到堆栈上。 |
堆栈转换行为依次为:
1.
将值 num 推送到堆栈上。
请注意,对于整数 -128 到 127 有特殊的简短编码(并因此更有效),对于整数 -1 到 8 尤其有特殊的简短编码。所有简短编码都将 4 字节整数推送到堆栈上。较长的编码用于 8 字节整数以及 4 和 8 字节浮点数,并且用于不适合短格式的 4 字节值。有三种方法可以将 8 字节整数常数推送到堆栈上
1. 使用 Ldc_I8 指令用于必须以超过 32 位表示的常数。
2. 使用 Ldc_I4 指令(后跟 Conv_I8)用于需要 9 到 32 位的常数。
3. 使用短格式指令(后跟 Conv_I8)用于可以 8 位或更少位表示的常数。
下表列出了指令的十六进制和 Microsoft 中间语言 (MSIL) 汇编格式,以及简短的参考摘要:
格式 |
汇编格式 |
说明 |
|
ldc.i4.s num |
将 num 作为 int32 推送到堆栈上(短格式)。 |
堆栈转换行为依次为:
1.
将值 num 推送到堆栈上。
对于将从 -127 到 128 的整数推送到计算堆栈,ldc.i4.s 是更有效的编码。
但是看了这东西后,感觉还是不是很清楚,就想直接理解,直接的理解就是在小于8大于0的情况下用的是ldc.i4
num ,而大于8 和小于0又是针对32位(之所以说是对于32位,是因为在64 位下还有ldc.i8
num )的机器编程就用 ldc.i4.s num 。
此外针对float32还有ldc.r4
num , 针对float64 还有ldc.r8 num ,最后一个是针对 -1用的是ldc.i4.m1。