栈帧与递归:深入理解程序执行机制
1. 引用参数
引用参数通常由过程使用基址偏移寻址(从 EBP)进行访问。由于每个引用参数都是一个指针,它通常被加载到寄存器中用作间接操作数。例如,假设数组的指针位于栈地址 [ebp + 12] ,以下语句将指针复制到 ESI:
mov esi,[ebp+12]
; points to the array
ArrayFill 示例
ArrayFill 过程用于用 16 位整数的伪随机序列填充数组。它接收两个参数:数组的指针和数组长度。第一个参数通过引用传递,第二个参数通过值传递。示例调用如下:
.data
count = 100
array WORD count DUP(?)
.code
push OFFSET array
push count
call ArrayFill
ArrayFill 内部的序言代码初始化栈帧指针(EBP):
ArrayFill PROC
push ebp
mov ebp,esp
此时栈帧包含数组偏移量、计数、返回地址和保存的 EBP。 ArrayFill 保存通用寄存器,检索参数并填充数组:
ArrayFi
超级会员免费看
订阅专栏 解锁全文
65

被折叠的 条评论
为什么被折叠?



