IL汇编ldc指令学习

ldc指令是把值送到栈上,

说明如下,

ldc.i4 将所提供的int32类型的值作为int32推送到计算堆栈上;

ldc.i4.0 将数值0作为int32推送到计算堆栈上;

...

ldc.i4.8 将数值8作为int32推送到计算堆栈上;

ldc.i4.m1 将数值-1作为int32推送到计算堆栈上;

ldc.i4.s 将提供的int8值作为int32推送到计算堆栈上(短格式);

ldc.i4 99,这样是把数值99送到栈上;

ldc.i4.s,也是把值送到栈上,但是需要提供的是一个字节长的整型;

i4是数据类型助记符,是指4字节的整型;s则是指 Single Byte ;

ldc.i4.s 11,这样是把数值11送到栈上;

ldc.i4.0 到 ldc.i4.8,是直接送最后的这个数值,0-8,到栈上;

示例;

cpp 复制代码
.assembly extern mscorlib {}
 
 .assembly Test
 {
     .ver 1:0:1:0
 }
 .module test.exe
  
 .method static void main() cil managed
 {
     .maxstack 12
     .entrypoint
     
     ldc.i4 202
     call void [mscorlib]System.Console::Write (int32)
     ldc.i4 303
     call void [mscorlib]System.Console::Write (int32)
     ldc.i4.6
     call void [mscorlib]System.Console::Write (int32)
     ldc.i4.5
     call void [mscorlib]System.Console::Write (int32)
     ldc.i4.m1
     call void [mscorlib]System.Console::Write (int32)
     ldc.i4.s 3000
     call void [mscorlib]System.Console::Write (int32)
     ret
 }

先把202送到栈上,然后输出;再把303送到栈上,然后输出;

然后把数值6送到栈上,然后输出;再把数值5送到栈上,然后输出;

再把数值-1送到栈上,然后输出;

然后看一下,ldc.i4.s 3000,会输出什么;带了.s之后需要提供一个字节长的整型,单字节整型的最大值是255;

运行如下;

没有输出回车换行,数字都是连在一起的,最后一次输出-72,倒数第二次输出-1;

有时间继续;

相关推荐
Ronin-Lotus12 天前
微处理器原理与应用篇---ARM常见汇编指令
汇编·arm开发·微处理原理与应用
永夜的黎明15 天前
【二进制安全作业】250616课上作业1-栈溢出漏洞利用
c语言·汇编·安全
Geometry Fu17 天前
物联网控制技术 知识点总结 第三章 汇编语言 第四章 C51语言
汇编·物联网·51单片机
半桔17 天前
【Linux手册】进程的状态:从创建到消亡的“生命百态”
linux·运维·服务器·汇编·深度学习·面试
一条叫做nemo的鱼20 天前
从汇编的角度揭开C++ this指针的神秘面纱(下)
java·汇编·c++·函数调用·参数传递
一条叫做nemo的鱼21 天前
从汇编的角度揭开C++ this指针的神秘面纱(上)
汇编·c++·算法·函数调用·this指针·参数传递
qwertyuiop_i23 天前
汇编(函数调用)
汇编·windows·函数调用
不忘不弃23 天前
由汇编代码确定switch语句
汇编
南玖yy23 天前
深入理解 x86 汇编中的符号扩展指令:从 CBW 到 CDQ 的全解析
开发语言·汇编·arm开发·后端·架构·策略模式
iCxhust23 天前
汇编字符串比较函数
c语言·开发语言·汇编·单片机·嵌入式硬件