| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 621 人关注过本帖
标题:[讨论]堆栈问题!
只看楼主 加入收藏
菜鸟上路
Rank: 4
等 级:贵宾
威 望:14
帖 子:1120
专家分:0
注 册:2006-3-21
收藏
 问题点数:0 回复次数:6 
[讨论]堆栈问题!
# include "stdio.h"

void f1(void){
int i,j;
i=ox12345678;
return;
}
void f2(void){
int m,n;
return m;
}

void main(){
int x;
f1();
m=f2();
printf("x=%x",x);
getch();
}
最后得到的是什么答案??
搜索更多相关主题的帖子: 堆栈 
2006-09-18 13:04
jxnuwy04
Rank: 2
等 级:新手上路
威 望:4
帖 子:768
专家分:0
注 册:2006-9-15
收藏
得分:0 
以下是引用菜鸟上路在2006-9-18 13:04:43的发言:
# include "stdio.h"

void f1(void){
int i,j;
i=ox12345678;//看不大懂
return;
}
void f2(void){
int m,n;
return m; //不是没有返回类型的吗?
}

void main(){
int x;
f1();
m=f2();
printf("x=%x",x);
getch();
}
最后得到的是什么答案??


------------------不为别的,就为你,我的理想!-----------------
2006-09-18 13:48
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
以下是引用菜鸟上路在2006-9-18 13:04:43的发言:
# include "stdio.h"

void f1(void){
int i,j;
i=ox12345678;//十六进制常数 i=0x12345678;
return;
}
void f2(void){
int m,n;
return m; //无返回值
}

void main(){
int x;
f1();
m=f2(); //m没有定义
printf("x=%x",x);//x是随机值
getch();
}
最后得到的是什么答案??

还有就是没有用到定义的变量.楼主是不是想测试局部变量和全局变量的作用范围


倚天照海花无数,流水高山心自知。
2006-09-18 17:43
菜鸟上路
Rank: 4
等 级:贵宾
威 望:14
帖 子:1120
专家分:0
注 册:2006-3-21
收藏
得分:0 
写错了,不好意思

# include "stdio.h"
void f1(void){
int i,j;
i=ox12345678;
return;
}
void f2(void){
int m,n;
return m;
}
void main(){
int x;
f1();
x=f2();
printf("x=%x",x);
getch();
}
我想知道为什么答案是12345678?
我认为是这样的:
入口 main函数,接着调用f1(); 然后在内存中分配一个栈,从f1()函数的入口处,先是参数入栈,然后定义局部变量,f1()分配8字节的空间存储i,j i赋值后返回栈底。接着调用f2(); f2()与f1()类似(我想给f1和f2分配的是相同的栈),在f2中也是定义相同数量相同类型的变量,而在这个栈中,i所赋的ox12345678并没有清除,所以结果是12345678。

不知道是不是这样理解的

2006-09-18 20:33
ww84020209
Rank: 1
等 级:新手上路
帖 子:190
专家分:0
注 册:2006-8-21
收藏
得分:0 

给你程序自己测试去.
# include "stdio.h"

void f1(void){
int i,j;
i=0x12345678;
printf("adress i:%x\n",&i);
printf("adress j:%x\n",&j);
printf("i=%x\n",i);
return ;
}
int f2(void){
int m,n;
printf("adress m:%x\n",&m);
printf("adress n:%x\n",&n);
printf("m=%x\n",m);
return m ;
}

void main(){
int m;
f1();
m=f2();
printf("m=%x\n",m);
}

i和m地址相同,j和n地址相同,但释放,在分配,里边的内容是不能保证的.(至少VC不行,TC2.0没有,自己测试去)


2006-09-18 21:45
SunShining
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:31
帖 子:2215
专家分:0
注 册:2006-2-17
收藏
得分:0 

释放并不是就把内存里的值清除掉.
只是让它回到堆栈中

而再次分配.赋值只是简单的覆盖!


[glow=255,violet,2]闭关修炼ing...[/glow] [FLASH=360,180]http://www./chinaren.swf[/FLASH]
2006-09-19 07:24
菜鸟上路
Rank: 4
等 级:贵宾
威 望:14
帖 子:1120
专家分:0
注 册:2006-3-21
收藏
得分:0 

谢谢大家给的宝贵意见呵


2006-09-19 12:13
快速回复:[讨论]堆栈问题!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017386 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved