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;

有时间继续;

相关推荐
浩浩测试一下8 小时前
汇编 位运算 (逆向分析)
汇编·逆向·位运算·asm·windows编程·二进制逆向
浩浩测试一下8 小时前
汇编 高低八位寄存器数据存储方式(逆向分析)
汇编·网络安全·逆向·二进制·免杀·寄存器·windows编程
a833319617 小时前
C语言嵌入汇编详解
汇编·单片机·语言
yoyo_zzm2 天前
汇编到PHP:五大编程语言核心特性全解析
开发语言·汇编·php
ComputerInBook3 天前
X64 汇编 MOVSD 的两种用法
汇编·汇编指令·movsd
YangWeiminPHD5 天前
金水32051编译器下的AI8051U单片机入门:从点亮LED到“你好,世界,我来了!”
c语言·汇编·51单片机·编译器
九思十安7 天前
HNU2026-计算机系统-笔记 5 汇编进阶
汇编·笔记
九思十安7 天前
HNU2026-计算机系统-笔记 4 汇编初步
汇编·笔记
这猪好帅8 天前
协程原理与实现
汇编
Byron Loong11 天前
【逆向】AT Hook 与 Inline Hook 对比
c语言·汇编·c++