免费注册 查看新帖 |

Chinaunix

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

[函数] 一个面试题,说是考函数调用方式 [复制链接]

论坛徽章:
0
51 [报告]
发表于 2007-09-10 13:57 |只看该作者
#include <stdio.h>

void test()
{
    int t;
    scanf("%d",&t);

    int *bp = (int*)( (&t)[1] );  //得到上一级栈帧
    bp[-1] = t;
}

main()
{
    int m;

    test();
    printf("%d",m);
}
budognai 该用户已被删除
52 [报告]
发表于 2007-09-22 20:54 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
53 [报告]
发表于 2007-09-23 12:10 |只看该作者
原帖由 Solidus 于 2007-9-8 13:02 发表
刚才说的没错,就是这样

main中的m被分配之后,先call的test 这里压入了eip,然后 test中又先压入了ebp,然后是t 这样子,
(&t)[0]就是t,(&t)[1]就是push 的ebp, (&t)[2]就是那个call压入的eip,(&t)[3]就是 ...



这个只能在特定的平台上才可能通过!因为C标准中没有规定函数调用时的实参入栈顺序、堆栈增长方向,这些是由平台与编译器来实现的。

论坛徽章:
0
54 [报告]
发表于 2007-09-23 17:28 |只看该作者
原帖由 紫牧 于 2007-9-8 11:56 发表
用C实在是做不出来,用汇编弄了个    _asm{
        push        eax
        push        ebx
        mov         eax,[ebp]
        lea           ebx,[ebp-4]
        mov         ebx,[ebx]
       ...


能一句一句解释一下吗 :wink:

论坛徽章:
0
55 [报告]
发表于 2007-09-25 01:39 |只看该作者
原帖由 cai_bird 于 2007-9-10 13:42 发表
严重同意楼上,技术是用来解决问题的,不是用来钻牛角尖的。


但面试题要解决的问题是怎样区分两个人, 他们怎样思考, 遇到困难怎样反应, 基础知识怎么样等等, 倒是不见得要你得出什么正确答案.
yyzz913 该用户已被删除
56 [报告]
发表于 2007-09-25 09:23 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
yyzz913 该用户已被删除
57 [报告]
发表于 2007-09-25 09:25 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
58 [报告]
发表于 2007-09-25 13:16 |只看该作者
破烂考题!
项目里要是有人敢这么写代码,立刻枪毙!懂了栈桢的结构的人,也不屑于去炫耀这种屠龙之技。

UNIX哲学认为: 我们宁愿用错误的方法解决正确的问题,也不愿意用正确的方法解决错误的问题!

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
59 [报告]
发表于 2007-09-25 13:19 |只看该作者
原帖由 JohnBull 于 2007-9-25 13:16 发表
破烂考题!
项目里要是有人敢这么写代码,立刻枪毙!懂了栈桢的结构的人,也不屑于去炫耀这种屠龙之技。

UNIX哲学认为: 我们宁愿用错误的方法解决正确的问题,也不愿意用正确的方法解决错误的问题!

恭喜你!你被录取了!

BTW:这才是正确答案。

论坛徽章:
0
60 [报告]
发表于 2007-09-25 14:23 |只看该作者
谁能把栈桢结构讲下啊?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP