汇编_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

相关推荐
鸽芷咕9 小时前
DOSBox 汇编环境搭建完整教程:安装配置 + MASM/LINK/DEBUG 工具链配置详解
汇编
Gofarlic_OMS21 小时前
UG/NX许可证管理高频技术问题解答汇编
java·大数据·运维·服务器·汇编·人工智能
iCxhust21 小时前
如何在汇编中修改CS:IP
汇编·单片机·嵌入式硬件·51单片机·微机原理
枷锁—sha2 天前
【CTFshow-pwn系列】03_栈溢出【pwn 073】详解:静态编译下的自动化 ROP 链构建
网络·汇编·笔记·安全·网络安全·自动化
wechatbot8883 天前
极客互动企业微信聚合聊天与接口能力全景展示
汇编·微信·企业微信·ipad
枷锁—sha4 天前
【CTFshow-pwn系列】03_栈溢出【pwn 072】详解:无字符串环境下的多级 Ret2Syscall 与 BSS 段注入
服务器·网络·汇编·笔记·安全·网络安全
iCxhust6 天前
8088汇编测试程序 (MASM/TASM) — 显示 “HELLO 8088!“ + “LCD1602 OK“
汇编·单片机·嵌入式硬件·51单片机·微机原理
lhbian7 天前
AI编程革命:Codex让脚本开发提速10倍
开发语言·汇编·jvm·c#
wechatbot8888 天前
企业微信全场景消息发送接口开发实现及接口调用
java·汇编·微信·企业微信
wechatbot8888 天前
企业微信 iPad 协议接口全功能开发实战
汇编·人工智能·ios·微信·企业微信·ipad