关于在函数中返回动态的内存

1.有以下题目:

 1 #include <iostream>
 2 using namespace std;
 3 
 4 void GetMemeory(char* p)
 5 {
 6     p=(char*)malloc(sizeof(char)*100);
 7 }
 8 
 9 int main()
10 {
11     char *str=NULL;
12     GetMemeory(str);
13     strcpy(str,"Thunder");
14     strcat(str,"Downloader");
15     printf(str);
16     system("pause");
17     return 0;
18 }

我们期望的输出是:ThunderDownloader

然而当我们运行此段代码的时候发现,程序崩溃了。

 

其实我们深入分析下不难发现,当我们传入str到GetMemeory()函数中的时候,该函数我们创建了一个临时

的指针变量片p,然后将其指向NULL。然后我们为临时指针变量p动态分配内存,注意,当我们在返回的时候

整个临时指针变量是释放掉的,因为其内存是在栈内存中分配的。但是我们之前传入的str的内存地址与临时变量

的内存地址是不相同的。所以此时str不能获取在函数GetMemmory分配的内存,因此后面的字符串复制和链接操作

都将造成程序崩溃。

 

我们可以用下面的图形更加生动的这一过程:

假设str本身内存为0x123  临时指针变量p的内存为0x456  动态分配的内存起始地址为0x789

当GetMemory函数结束的时候p被释放,而再也无指针指向这块动态分配的内存了。另外str也不可能

获取这段动态分配的内存的地址。所以也造成了内存泄露。

 

我们可以用如下两种方法解决这一问题:

一种是二级指针:

 1 #include <iostream>
 2 using namespace std;
 3 
 4 void GetMemeory(char** p)
 5 {
 6     (*p)=(char*)malloc(sizeof(char)*100);
 7 }
 8 
 9 int main()
10 {
11     char *str=NULL;
12     GetMemeory(&str);
13     strcpy(str,"Thunder");
14     strcat(str,"Downloader");
15     printf(str);
16     system("pause");
17     return 0;
18 }

运行截图为:

关于二级指针的方法可以参考如下的流程图:

 

 

 

 

一种是指针的引用方法:

 1 #include <iostream>
 2 using namespace std;
 3 
 4 void GetMemeory(char*& p)
 5 {
 6     p=(char*)malloc(sizeof(char)*100);
 7 }
 8 
 9 int main()
10 {
11     char *str=NULL;
12     GetMemeory(str);
13     strcpy(str,"Thunder");
14     strcat(str,"Downloader");
15     printf(str);
16     system("pause");
17     return 0;
18 }

运行截图:

关于指针引用方法的流程图如下:

 

能力有限,难免有没说清楚的地方,还望包涵。

 

posted @ 2015-08-31 16:50  vpoet  阅读(1578)  评论(1编辑  收藏  举报