汇编-间接寻址(处理数组)

直接寻址很少用于数组处理,因为用常数偏移量来寻址多个数组元素时,直接寻址并不实用。取而代之的是使用寄存器作为指针(称为间接寻址(indirect addressing) ) 并控制该寄存器的值。如果一个操作数使用的是间接寻址, 就称之为间接操作数(indie ct operand) 。

间接操作数

保护模式下任何一个32位通用寄存器(EAX、EBX、ECX、EDX、ESI、EDI、EBP及ESP) 用中括号括起来就成为间接操作数。寄存器中包含的是数据的地址

复制代码
.386  
.model flat,stdcall 
option casemap:none

.data   
byteVal BYTE 10h


ExitProcess PROTO,dwExitCode:DWORD      

.code  
main PROC   
	
	mov esi, OFFSET byteVal 
	mov al, [esi]            ;AL=10h,[esi]表示esi地址中的数据


INVOKE ExitProcess,0  
main ENDP   
END main  

如果目的操作数使用间接寻址,则新值将存入由寄存器指向的内存位置。

复制代码
.386  
.model flat,stdcall 
option casemap:none

.data   
byteVal BYTE 10h

ExitProcess PROTO,dwExitCode:DWORD      

.code  
main PROC   
	
	mov bl,88h
	mov esi , OFFSET byteVal
	mov [esi],bl                ;把bl中的值存入esi表示的地址中
	mov al,[esi]            ;al=88h


INVOKE ExitProcess,0  
main ENDP   
END main  

PTR与间接操作数一起使用

PTR与间接操作数一起使用一个操作数的大小可能无法从指令的上下文直接看出来。

下面的指令会导致汇编器产生"operand must have size"(操作数必须有大小) 的报错消息:

inc [esi]

汇编器不知道ESI指向的是字节、字、双字, 或其他数据大小。

PTR操作符则可以确定操作数的大小,如下例所示:

复制代码
.386  
.model flat,stdcall 
option casemap:none

.data   

val BYTE 12h 

ExitProcess PROTO,dwExitCode:DWORD      

.code  
main PROC   
	
	mov esi,OFFSET val
	inc BYTE PTR [esi]   ;指明BYTE大小
	mov eax,[esi]        ;EAX = 00000013


INVOKE ExitProcess,0  
main ENDP   
END main  
相关推荐
浩浩测试一下18 小时前
抬栈 恢复上下文 (逆向分析)
汇编·逆向·堆栈·windows核心编程
zhouwy11318 小时前
ARM汇编指令集详解
汇编·arm开发
iCxhust18 小时前
微机原理实践教程(汇编篇)---A002流水灯
汇编·单片机·嵌入式硬件·51单片机·微机原理
浩浩测试一下19 小时前
栈帧 抬栈与平栈 (逆向分析)
汇编·windows api·堆栈·windows编程·windows 开发
陈eaten19 小时前
win11下nasm编写汇编及链接方案
汇编·链接·nasm·gcc·golink
iCxhust19 小时前
【无标题】8086/8088裸机对于学习微机原理的重要意义
汇编·单片机·嵌入式硬件·嵌入式·微机原理
鸽芷咕3 天前
DOSBox 汇编环境搭建完整教程:安装配置 + MASM/LINK/DEBUG 工具链配置详解
汇编
Gofarlic_OMS4 天前
UG/NX许可证管理高频技术问题解答汇编
java·大数据·运维·服务器·汇编·人工智能
iCxhust4 天前
如何在汇编中修改CS:IP
汇编·单片机·嵌入式硬件·51单片机·微机原理
枷锁—sha5 天前
【CTFshow-pwn系列】03_栈溢出【pwn 073】详解:静态编译下的自动化 ROP 链构建
网络·汇编·笔记·安全·网络安全·自动化