zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    pycharm上传代码到码云(详细)
    我是如何理解ThreadLocal
    前两次成绩汇总
    第五次作业
    第四次作业
    第三次作业
    第二次作业
    第一次作业
    单例模式之懒汉式与饿汉式
    浅谈对srping框架的理解
  • 原文地址:https://www.cnblogs.com/jianggest/p/ldc.html
Copyright © 2011-2022 走看看