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

1.有如下题目:ios

 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函数

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

 

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

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

整个临时指针变量是释放掉的,由于其内存是在栈内存中分配的。可是咱们以前传入的str的内存地址与临时变量code

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

都将形成程序崩溃。内存

 

咱们能够用下面的图形更加生动的这一过程:字符串

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

当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 }

运行截图:

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

 

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

相关文章
相关标签/搜索