所以我试着通过查看这里的程序集来编写一些C代码:
pushl %ebp
movl %esp, %ebp
movl 12(%ebp), %eax
addl 8(%ebp), %eax
movzbl (%eax), %eax
movsbl %al,%eax
popl %ebp
ret
Run Code Online (Sandbox Code Playgroud)
我看到我有两个变量,它们被加在一起,然后当看到函数开始调用movzbl和movesbl时我迷路了.这里发生了什么?
相应的C函数就像是
char fn(char * string, int index)
{
return string[index];
}
Run Code Online (Sandbox Code Playgroud)
具体来说,movzbl指令取出存储在两个参数之和的字节,零填充它,并将其存储eax.该movsbl指令采用eax的最低字节,符号扩展它,并将结果存储回eax.