设为首页收藏本站

新微赢技术网

 找回密码
 注册
搜索
热搜: 回贴
查看: 646|回复: 3
打印 上一主题 下一主题

关于函数调用机制

[复制链接]
跳转到指定楼层
1#
发表于 2009-11-4 01:21:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请教各位:我对函数调用机制中的栈操作不是很理解,有谁能帮我解释下,在函数返回时,栈区是如何操作的
int func1();
int func2();

void main()
{
func1();
cout<<func2()<<endl;
}

int func1()
{
int n=1234;
return n;
}

int func2()
{int m;
return m;
}
书上说最后输出结果是1234,我搞不明白,也没调试出来,恳请大家帮忙解释下!谢谢!
2#
发表于 2009-11-4 01:21:04 | 只看该作者
这种垃圾代码没有意义
楼主以后别看这种书
回复 支持 反对

使用道具 举报

3#
发表于 2009-11-4 01:21:05 | 只看该作者
fun1 将原来空间 释放后, 内存中仍然保存原来的值...这时 有分配新的m ,刚好是原来 1234的地址,所有输出1234

具体 可以 看看 汇编 语言中的 入栈和出栈操作
回复 支持 反对

使用道具 举报

4#
发表于 2009-11-4 01:21:06 | 只看该作者
这个多线程支持么??
不会这么巧合了吧
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

申请友链|小黑屋|最新主题|手机版|新微赢技术网 ( 苏ICP备08020429号 )  

GMT+8, 2024-11-18 23:38 , Processed in 0.076315 second(s), 10 queries , Gzip On, Memcache On.

Powered by xuexi

© 2001-2013 HaiAn.Com.Cn Inc. 寰耽

快速回复 返回顶部 返回列表