LEA 指令返回间接操作数的地址。由于间接操作数中包含一个或多个寄存器,因此会在运行时计算这些操作数的偏移量。为了演示如何使用 LEA,现在来看下面的 C++ 程序,该程序声明了一个局部数组 myString,并引用它来分配数组值:
void makeArray()
{
char myString[30];
for ( int i = 0; i < 30; i++ )
myString[i] = '*';
}
与之等效的汇编代码在堆栈中为 myString 分配空间,并将地址(间接操作数)赋给 ESI。虽然数组只有 30 个字节,但是 ESP 还是递减了 32 以对齐双字边界。注意如何使用 LEA 把数组地址分配给 ESI:
makeArray PROC
push ebp
mov ebp,esp
sub esp, 32 ;myString 位于 EBP-30 的位置
lea esi, [ebp-30] ;加载 myString 的地址
mov ecx, 30 ;循环计数器
LI: mov BYTE PTR [esi] ;填充一个位置
inc esi ;指向下一个元素
loop LI ;循环,直到 ECX=0
add esp, 32 ;删除数组(恢复ESP)
pop ebp
ret
makeArray ENDP
不能用 OFFSET 获得堆栈参数的地址,因为 OFFSET 只适用于编译时已知的地址。下面的语句无法汇编: