免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: 爱知
打印 上一主题 下一主题

C 转化为汇编后,一些语句代码的困惑 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2008-11-21 08:41 |只看该作者
1、 你明白 leal 4(%esp), %ecx, .... push -4(%esp) 是什么意思吗?

我认为 %ecx 是多余的.

  1. 6:                leal        4(%esp), %ecx               
  2. 8:                pushl        -4(%ecx)
  3. 11:                pushl        %ecx
复制代码

我这样解释对吗?

6>把 4(%esp) 的偏移地址送入 %ecx
8>把 -4(%ecx) 的内容压入栈中(也即是把 andl 句前栈顶元素再次压入到栈中,改变 %esp)
11>把 %ecx 压入栈

8句的作用是什么?

[ 本帖最后由 爱知 于 2008-11-21 08:45 编辑 ]

论坛徽章:
0
12 [报告]
发表于 2008-11-22 00:26 |只看该作者
给你看看我以前画的一个gcc汇编后main函数的堆栈分析图

也许对你有帮助~~

stack_of_main.tar.bz2

992 Bytes, 下载次数: 58

论坛徽章:
0
13 [报告]
发表于 2008-11-23 14:43 |只看该作者

回复 #12 BLZer 的帖子

谢谢 你的 “堆栈分析图”

我原来还以为 %ecx 的作用只是为了“pushl -4(%ecx)”句呢
现在才注意到 %ecx 是用来保存最初的 %esp 的(不能直接 pushl %esp, 因为 andl 改变了 %esp, 必须在之前保存 %esp)
所以一楼中1问本身是错误的。

我想再问一下:
1》堆栈图中,“name of programe”,“num of parameters” 是指“所调用函数名”、“函数参数的个数”吗?
   难道这些 函数名,函数参数个数 在被调用时也压入栈中吗?在 main 和其他函数中应该同样吧?

2》在“andl $-16, %esp”句后,“pushl -4(%ecx)” 就是把“num of parameters”又重新复制到栈顶,
   这个为何?(这个地址中的数据以后并没有用到呀)这一句是否为多余?难道其用途没在本函数中显现?

论坛徽章:
0
14 [报告]
发表于 2010-11-08 15:28 |只看该作者
回复 12# BLZer


    非常感谢你的gcc汇编后main函数的堆栈分析图;我正对这个问题苦恼
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP