扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
“作为一名合格的程序员,汇编语言的知识是必不可少的。”
1、intel汇编与AT&T格式的汇编不同之处也知道也写,今天看到一条以前没见过的:
(变量)符号的地址以“$”开头,注意是变量的地址。
movl $var,%ebx
区别:movl var,%ebx
2、函数调用过程中,关于参数压栈,和返回后执行指令的地址。
伪码:
.globl fun
.type fun,@functionfun:
pushl %ebp
movl %esp,%ebp
subl $4,%esp
movl 8(%ebp),%eax
movl %eax,-4(%ebp)
movl $3,8(%ebp)
mov $4,12(%ebp)
...
.globl main
.type main,@function
main:
...
movl $100,(%esp)
movl $200,4(%esp)
call fun
movl $0,%eax
...
上面代码中,由于4(%ebp)中放置的是从fun函数返回后执行的第1条指令的地址(该地址由“call fun”自动压栈),所以在fun函数中取两个参数时的地址时是
movl $3,8(%ebp)
mov $4,12(%ebp)。
3、在函数调用过程中,为什么不直接使用esp寻址栈里面的数据,而要先保存ebp,在用ebp存放esp,在通过ebp来寻址?
其实直接用esp寻址也是可以的,只是gcc默认输出的汇编代码是用ebp寻址,而用esp勾画整个函数的栈空间。这样代码比较清晰。如果要追求高效,如在编译linux内核时,其内部函数就是直接用esp寻址的。可以用编译选项指示GCC直接用esp寻址:
$gcc -fomit -frame -poin
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者