我正在尝试编写一些C代码,通过查看这里的汇编代码:
pushl %ebp
movl %esp, %ebp
movl 12(%ebp), %eax
addl 8(%ebp), %eax
movzbl (%eax), %eax
movsbl %al,%eax
popl %ebp
ret
我看到有两个变量,它们被相加在一起,然后当函数开始调用movzbl和movesbl时,我就迷失了。这里发生了什么?
我正在尝试编写一些C代码,通过查看这里的汇编代码:
pushl %ebp
movl %esp, %ebp
movl 12(%ebp), %eax
addl 8(%ebp), %eax
movzbl (%eax), %eax
movsbl %al,%eax
popl %ebp
ret
我看到有两个变量,它们被相加在一起,然后当函数开始调用movzbl和movesbl时,我就迷失了。这里发生了什么?
对应的 C 函数可能是这样的:
char fn(char * string, int index)
{
return string[index];
}
具体来说,movzbl
指令获取存储在两个参数之和处的字节,使用零填充并将其存储到 eax
中。 movsbl
指令获取 eax
的最低字节,扩展符号,并将结果存储回 eax
。