
【本节目标】
今天我们来学习对串操作的操作数
- 明白movsd的使用,观察其在汇编模式下的内存和寄存器的变化
- 学会使用rep指令
- 掌握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
