首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C语言 >

C语言 return 有关问题

2012-03-17 
C语言return问题C/C++ code1 #includestdio.h2 char* fun()3 {4char *strhere is string 5return st

C语言 return 问题

C/C++ code
  1 #include<stdio.h>  2 char* fun()  3 {  4     char *str="here is string ";  5         return str;  6 }  7 char* fun1()  8 {  9     char str[100]="here is array "; 10         return str; 11 } 12 int fun2() 13 { 14     int a=10; 15         return a; 16 } 17 char* fun3() 18 { 19    char str[]="here is array "; 20           return str; 21 } 22 void main() 23 { 24     printf("%s \n",fun()); 25     printf("%s \n",fun1()); 26     printf("%d \n",fun2()); 27     printf("%s \n",fun3()); 28 }
 

return语句不可返回指向“栈内存”的“指针”或者“引用”,因为该内存在函数体结束时被自动销毁 为什么fun() fun1() fun2() 都可以正常返回

[解决办法]
对哦 没用取值的*也成功返回了哦。。好玩
[解决办法]
这是系统的内存管理机制...

Windows环境下,并不会直接销毁掉所谓的局部变量...而是等CPU空闲时再去处理的...
要是立该去处理,如果是很多内存,这就会降低效率...

不过大多是等到再次使用到该内存的地址时,系统才会对其进行初始化!
[解决办法]
应该只有fun(值存在常量区) 和 fun2(返回时保存了该整形值) 能正常返回吧、
[解决办法]
2 char* fun()
3 {
4 char *str="here is string ";
5 return str;
6 }
因 
为fun内的“here is string ”是常量字符串,位于静态存储区,它在程序生命期 
内恒定不变。无论什么时候调用fun,它返回的始终是同一个“只读”的内存块

[解决办法]
了解每种变量的生命周期就知道能不能返回了
[解决办法]
楼主理解错了吧?不是str的生命周期,是看fun的生命周期。
[解决办法]
除了第一个和第三个。其他都错。运行结果正确不代表逻辑正确。变量被销毁,内存被回收都是谭浩强之流的说法(如果猜错了,谭的粉丝请见谅),不是c语言的说法。C语言规定自动变量的生命周期,第二第四个例子是间接访问(例中通过指针)过期的变量(例中的数组)。所以是错的。这才是根本原因。
[解决办法]
回收时间不确定
[解决办法]
lz 首先要理解 c 的返回机制,它也是传值的,即有一个临时变量存储返回的数值

fun() 中的字符串常量存储在常量区,不在 stack;
fun2().....

fun1()中的 stack 虽然被销毁,但没有被新的数值 overwrite,所以保存着原来的值,但这只是运气(好/不好?)(想一想被误删除的文件为何有时可以被恢复)
[解决办法]
楼主可以参考一下:
关于函数返回值的几种情况
[解决办法]
这个问题在于printf上,如果你这么写呢?char* p1 = fun1(); printf("%s \n",p1);


[解决办法]
VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

热点排行