2018年3月29日晚计组实验引发思考:关于c语言指针

主要分两方面。第一方面,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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值