科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件汇编语言小节(1)

汇编语言小节(1)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

符号的地址 函数调用过程 参数压栈 esp寻址。

作者:Paid 来源:CSDN 2008年3月27日

关键字: 小节 汇编 语言 汇编语言 Linux

  • 评论
  • 分享微博
  • 分享邮件

“作为一名合格的程序员,汇编语言的知识是必不可少的。”

1、intel汇编与AT&T格式的汇编不同之处也知道也写,今天看到一条以前没见过的:

(变量)符号的地址以“$”开头,注意是变量的地址。

movl $var,%ebx

区别:movl var,%ebx

2、函数调用过程中,关于参数压栈,和返回后执行指令的地址。

伪码:

.globl fun

.type fun,@function

fun:

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领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章