学习:CMP/TEST比较指令
cmp指令:比较
cmp指令,和sub指令的最大的不同点就是cmp指令是影响标志位 不储存结果
1、当前汇编指令为cmp edx,ecx
2、当前ecx寄存器中的地址为00000001,edx寄存器中的地址00000000,相当于 edx = edx - ecx
3、单步步过
结果发现ecx寄存器中没有变化
1、当前汇编指令为cmp eax,ecx
2、当前eax寄存器中的地址为00000001,ecx寄存器中的地址00000001,相当于 eax = eax-ecx
3、单步步过
结果发现ecx寄存器中没有变化,但是发现Z标志位发生了变化 变为了1,也可以说明了当cmp指令为两个相减为0的时候,那么Z标志位为1
如何进行对字符串的比较呢,这里自己理解的是对寄存器中的地址中的值进行比较比如如下
再进行重新设置EIP然后单步步过,结果如下,发现Z标志位变0,所以大小不一致
同样的,cmp影响的不只是Z标志位,之前S标志位是根据正负数来判断的,这里同样生效
1、当前汇编指令为cmp eax,ecx
2、当前eax寄存器中的地址为00000000,ecx寄存器中的地址00000001,相当于 eax = eax-ecx
3、单步步过
结果发现,S标志位为1,因为相减为负数
当然,cmp指令不只是寄存器与寄存器之间,还可以寄存器与地址的值之间,比如:
1、当前汇编指令为cmp eax,[402000]
2、设置地址402000中的值为01
3、单步步过
结果Z为1 那么相减结果为0,S为0,那么结果不是负数
test指令:对两个操作数进行与操作,同时影响符号标志位、零标志位和奇偶标志位
test指令就是进行与运算,如果与运算结果为0那么Z标志位为1,反之为0
1、当前汇编指令为cmp eax,ecx
2、设置EAX寄存器地址为00000001,ECX寄存器地址00000010,
3、单步步过
发现Z标志位为1,说明是相等,00000001的二进制为00000001, 00000010的二进制位为00010000,与运算结果为00000000
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY