Ldc.i4 num 和 ldc.i4.s num 的区别

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) 汇编格式,以及简短的参考摘要:

格式

汇编格式

说明

1F < int8 >

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

posted @ 2009-05-04 20:35  jianggest  阅读(3813)  评论(1编辑  收藏  举报