汇编_movsd和stosd

【本节目标】

今天我们来学习对串操作的操作数

  1. 明白movsd的使用,观察其在汇编模式下的内存和寄存器的变化
  2. 学会使用rep指令
  3. 掌握stosd的使用

1. movs/movsb/movsw/movsd-数据从字符串移到字符串

注意其寄存器固定死了

说明:

将第二个操作数(源操作数)指定的字节、字或双字移到第一个操作数(目标操作数)指定的位置。源操作数与目标操作数都是内存位置。(特殊指令,可以同时改变内存)源操作数的地址从DS:ESI或DS:SI寄存器中读取(具体取决于指令的地址大小属性,分别为32或16)。目标操作数的地址从ES:EDI或ES:DI寄存器中读取(具体也取决于指令的地址大小属性)。DS段可以用跨段前缀覆盖,但ES段不能覆盖。

movsb 把[esi]里面的一个字节移动到[edi]里面

movsw 把[esi]里面的两个字节移动到[edi]里面

movsd 把[esi]里面的四个字节移动到[edi]里面

  • b是代表byte;w是代表word;d是代表dword

1.1 movsd

此时先记住内存寄存器,下面我们来看看会发生什么变化

  • 同理movsd改为movsb,那么就是把ESI内存里面1个字节给到EDI,然后ESI和EDI同时加1;
  • 同理movsd改为movsw,那么就是把ESI内存里面2个字节给到EDI,然后ESI和EDI同时加2;

补充:

  • cld-清除DF标志 df=0 ------>递增(c代表clear)
  • std-设置DF标志 df=1 ------>递减(s代表set)

1.2 rep-重复执行

按计数寄存器((E)CX)中指定的次数重复执行字符串指令,或是重复到ZF标志不再满足指定的条件。REP(重复)

  • 看ECX ECX=0,那么结束重复
  • REP前缀可以添加到INS、OUTS、MOVS、LODS 及STOS 指令。(不要随意添加REP)

重复的是ESI给EDI的这个指令


1.3 STOS/STOSB/STOSW/STOSD-存储字符串

stosb 把AL的值移动到[edi]

stosw 把AX的值移动到[edi]

stosd 把EAX的值移动到[edi]

下面我们那stosd指令来举一个例子:

下面我们观察一下变化:

所以:stosd相当于指令:

  • mou dword ptr ds:[edi],eax
  • add edi,0x4

同理:

  • 如果stosd改为stosw,那就是改变两个字节,然后EDI+2
  • 如果stosd改为stosb,那就是改变一个字节,然后EDI+1

注意:

如果在stosd这条指令前面加上std这个指令,那么EDI就是做减法,因为EDI会改变DF的值,变为一,那么stosd这个指令就让EDI-4;同理stosb-1;stosw-2

相关推荐
一品人家21 小时前
win32汇编使用GDI+入门教程之六
汇编·windows·win32汇编
前端菜鸟日常2 天前
鸿蒙开发实战:100 个项目疑难杂症汇编
汇编·华为·harmonyos
188号安全攻城狮3 天前
【PWN】HappyNewYearCTF_9_ret2syscall
linux·汇编·安全·网络安全·系统安全
万法若空3 天前
Vim常用指令汇编
汇编·编辑器·vim
请输入蚊子4 天前
«操作系统真像还原» 第二章 编写MBR主引导记录
linux·汇编·操作系统·bochs·操作系统真像还原
188号安全攻城狮4 天前
【PWN】HappyNewYearCTF_8_ret2csu
linux·汇编·安全·网络安全·系统安全
切糕师学AI7 天前
ARM 汇编指令系列文章导读
汇编·arm开发
果粒蹬i7 天前
从割裂到融合:MATLAB与Python混合编程实战指南
开发语言·汇编·python·matlab
AUVpwoxkW9 天前
关键词:混合储能,VMD,麻雀搜索算法,遗传算法,混合储能容量配置优化,混合储能功率分配
汇编
取个名字太难了a9 天前
x64(一)
汇编