主要分两方面。第一方面,return栈内存指针。实验一第五题中,计算矩阵平方的函数为:int* result(zip_dig* in)(zip_dig是长度为五的一维数组),在函数中计算的结果正确,在返回后,地址与函数中地址相同,也没有在返回后对此段内存做过人为改动,但是输出的值却与函数中不同。
如图。随之网上搜索原因。
搜索出如下博客:
转载地址:http://www.cnblogs.com/micky-zhou/archive/2012/08/08/2628773.html
用函数返回值来传递动态内存这种方法虽然好用。但是常常有人把return语句用错了。
我们强调一定不要用return语句返回指向“栈内存”的指针,因为栈内存空间在函数结束后被释放了。
1 我在用g++编译如下程序的时候,使用的命令是
"g++ -Wall -g getString.cpp -o getString",用gdb调试程序。结果很令人疑惑。
1 #include<iostream> 2 using namespace std; 3 4 char *GetString(void) 5 { 6 char p[]="hello world"; 7 reaturn p; 8 } 9 10 int main(int argc,char *argv[]) 11 { 12 char *str = NULL; 13 str = GetString(); 14 cout<<str<<endl; 15 return 0; 16 17 }
在上述程序实例中,明显是一个返回栈内存的例子。
可是在gdb里面调试程序
str = 0xbffff3f0 "hello world"
充分说明str所指内存的内容确实是“hello world”
而在cout的时候却又是“乱码垃圾”,又证实了无法返回栈内存的思想。疑惑当中。
2 用vc调试的时候,发现了同样的结果,调试的过程出现了同样的问题,
悲催的初学者,呵呵。我一直觉得这应该不是一个很难的问题,肯定是我哪方面理解的不到位。
Remark/Solve:
对于数组来说,它是一个局部变量,是放在栈里面的。而在栈销毁之前,函数返回的指针已经传递给了生存期更长的str指针变量,所以str指向的内容也就是程序中的“hello world”, 当我们打印结果的时候,看出它的地址还是没有变,但是为什么内容会变掉 呢,难道是系统会把栈中的数据清除,答案是否定的,因为这样做会消耗系统的资源,而且没有任何好处,下次用到这块内存还是会进行初始化的。打印出来的内容 变掉是因为cout本身也是一个函数,也会进行参数的压栈,在
压栈的过程中会把原来str指向的空间覆盖掉,也就改变了其中的值。如果我们在 GetString之后,不调用任何函数并不创建新的局部变量(严格的说是不使栈继续往下增长),这个时候p指向的内容还是没变的。所以我们在调试程序的的时候,在运行cout函数之前,str指向的内容是我们想要的结果,好像实现了函数的作用,其实结果不是的。
以下为我对此博客观点:
不论cout或是其他会影响栈空间,(实际上我尝试不用cout改用printf也一样输出错误,以我水平并不理解为什么栈空间改变了,怎么样改变的)。但是
切记:return 语句不可返回指向“栈内存”的“指针”或者“引用”,因为该内存在函数体结束时被自动销毁。
另附另一篇关于此博客:https://blog.csdn.net/a_sungirl/article/details/10552447