1、有以下題目:
#include <iostream>using namespace std;void GetMemeory(char* p){ p=(char*)malloc(sizeof(char)*100);}int main(){ char *str=NULL; GetMemeory(str); strcpy(str,"Thunder"); strcat(str,"Downloader"); printf(str); system("pause"); return 0;}
我們期望的輸出是:ThunderDownloader
然而當(dāng)我們運(yùn)行此段代碼的時(shí)候發(fā)現(xiàn),程序崩潰了。
其實(shí)我們深入分析下不難發(fā)現(xiàn),當(dāng)我們傳入str到GetMemeory()函數(shù)中的時(shí)候,該函數(shù)我們創(chuàng)建了一個(gè)臨時(shí)
的指針變量片p,然后將其指向NULL。然后我們?yōu)榕R時(shí)指針變量p動(dòng)態(tài)分配內(nèi)存,注意,當(dāng)我們?cè)诜祷氐臅r(shí)候
整個(gè)臨時(shí)指針變量是釋放掉的,因?yàn)槠鋬?nèi)存是在棧內(nèi)存中分配的。但是我們之前傳入的str的內(nèi)存地址與臨時(shí)變量
的內(nèi)存地址是不相同的。所以此時(shí)str不能獲取在函數(shù)GetMemmory分配的內(nèi)存,因此后面的字符串復(fù)制和鏈接操作
都將造成程序崩潰。
我們可以用下面的圖形更加生動(dòng)的這一過(guò)程:
:
假設(shè)str本身內(nèi)存為0x123 臨時(shí)指針變量p的內(nèi)存為0x456 動(dòng)態(tài)分配的內(nèi)存起始地址為0x789
當(dāng)GetMemory函數(shù)結(jié)束的時(shí)候p被釋放,而再也無(wú)指針指向這塊動(dòng)態(tài)分配的內(nèi)存了。另外str也不可能
獲取這段動(dòng)態(tài)分配的內(nèi)存的地址。所以也造成了內(nèi)存泄露。
我們可以用如下兩種方法解決這一問(wèn)題:
一種是二級(jí)指針:
#include <iostream>using namespace std;void GetMemeory(char** p){ (*p)=(char*)malloc(sizeof(char)*100);}int main(){ char *str=NULL; GetMemeory(&str); strcpy(str,"Thunder"); strcat(str,"Downloader"); printf(str); system("pause"); return 0;}
運(yùn)行截圖為:
關(guān)于二級(jí)指針的方法可以參考如下的流程圖:
一種是指針的引用方法:
#include <iostream>using namespace std;void GetMemeory(char*& p){ p=(char*)malloc(sizeof(char)*100);}int main(){ char *str=NULL; GetMemeory(str); strcpy(str,"Thunder"); strcat(str,"Downloader"); printf(str); system("pause"); return 0;}
運(yùn)行截圖:
關(guān)于指針引用方法的流程圖如下:
能力有限,難免有沒(méi)說(shuō)清楚的地方,還望包涵。
以上就是小編為大家?guī)?lái)的淺談在函數(shù)中返回動(dòng)態(tài)的內(nèi)存全部?jī)?nèi)容了,希望大家多多支持武林網(wǎng)~
新聞熱點(diǎn)
疑難解答
圖片精選