char* AllocStrFromStack()
{
char pstr[100];
return pstr;
}
堆內(nèi)存分配:(典型的函數(shù):malloc)
char* AllocStrFromHeap(int len)
{
char *pstr;
if ( len <= 0 ) return NULL;
return ( char* ) malloc( len );
}
堆內(nèi)存分配:(典型的函數(shù):malloc)
char* AllocStrFromHeap(int len)
{
char *pstr;
if ( len <= 0 ) return NULL;
return ( char* ) malloc( len );
}
對(duì)于第一個(gè)函數(shù),那塊pstr的內(nèi)存在函數(shù)返回時(shí)就被系統(tǒng)釋放了。于是所返回的char*什么也沒(méi)有。而對(duì)于第二個(gè)函數(shù),是從堆上分配內(nèi)存,所以哪怕是程序退出時(shí),也不釋放,所以第二個(gè)函數(shù)的返回的內(nèi)存沒(méi)有問(wèn)題,可以被使用。但一定要調(diào)用free釋放,不然就是Memory Leak!
對(duì)于第一個(gè)函數(shù),那塊pstr的內(nèi)存在函數(shù)返回時(shí)就被系統(tǒng)釋放了。于是所返回的char*什么也沒(méi)有。而對(duì)于第二個(gè)函數(shù),是從堆上分配內(nèi)存,所以哪怕是程序退出時(shí),也不釋放,所以第二個(gè)函數(shù)的返回的內(nèi)存沒(méi)有問(wèn)題,可以被使用。但一定要調(diào)用free釋放,不然就是Memory Leak!
在堆上分配內(nèi)存很容易造成內(nèi)存泄漏,這是C/C++的最大的“克星”,如果你的程序要穩(wěn)定,那么就不要出現(xiàn)Memory Leak。
剛好前一段時(shí)間有一個(gè)Linux上的服務(wù)應(yīng)用程序,大約有幾百的C文件編譯而成,運(yùn)行測(cè)試良好,等使用時(shí),時(shí)間一長(zhǎng)內(nèi)存占用率就偏高,搞得許多人焦頭爛額,查不出問(wèn)題所在。出現(xiàn)這種問(wèn)題就是MemeryLeak在做怪了,在C/C++中這種問(wèn)題總是會(huì)發(fā)生,所以你一定要小心。一個(gè)Rational的檢測(cè)工作——Purify,可以幫你測(cè)試你的程序有沒(méi)有內(nèi)存泄漏。我保證,做過(guò)許多C/C++的工程的程序員,都會(huì)對(duì)malloc或是new有些感冒。當(dāng)你什么時(shí)候在使用malloc和new時(shí),有一種輕度的緊張和惶恐的感覺(jué)時(shí),你就具備了這方面的修養(yǎng)了。
在堆上分配內(nèi)存很容易造成內(nèi)存泄漏,這是C/C++的最大的“克星”,如果你的程序要穩(wěn)定,那么就不要出現(xiàn)Memory Leak。
剛好前一段時(shí)間有一個(gè)Linux上的服務(wù)應(yīng)用程序,大約有幾百的C文件編譯而成,運(yùn)行測(cè)試良好,等使用時(shí),時(shí)間一長(zhǎng)內(nèi)存占用率就偏高,搞得許多人焦頭爛額,查不出問(wèn)題所在。出現(xiàn)這種問(wèn)題就是MemeryLeak在做怪了,在C/C++中這種問(wèn)題總是會(huì)發(fā)生,所以你一定要小心。一個(gè)Rational的檢測(cè)工作——Purify,可以幫你測(cè)試你的程序有沒(méi)有內(nèi)存泄漏。我保證,做過(guò)許多C/C++的工程的程序員,都會(huì)對(duì)malloc或是new有些感冒。當(dāng)你什么時(shí)候在使用malloc和new時(shí),有一種輕度的緊張和惶恐的感覺(jué)時(shí),你就具備了這方面的修養(yǎng)了。
對(duì)于malloc和free的操作有以下規(guī)則:
1) 配對(duì)使用,有一個(gè)malloc,就應(yīng)該有一個(gè)free。(C++中對(duì)應(yīng)為new和delete)
2) 盡量在同一層上使用,不要像上面那種,malloc在函數(shù)中,而free在函數(shù)外。最好在同一調(diào)用層上使用這兩個(gè)函數(shù)。
3) malloc分配的內(nèi)存一定要初始化。free后的指針一定要設(shè)置為NULL。
4) 設(shè)計(jì)自己的內(nèi)存分配鏈表,記載已經(jīng)分配的內(nèi)存,便于在釋放的時(shí)候有備可查
注:雖然現(xiàn)在的操作系統(tǒng)(Linux和Windows)都有進(jìn)程內(nèi)存跟蹤機(jī)制,也就是如果你有沒(méi)有釋放的內(nèi)存,操作系統(tǒng)會(huì)幫你釋放。但操作系統(tǒng)依然不會(huì)釋放你程序中所有產(chǎn)生了Memory Leak的內(nèi)存,所以,最好還是你自己來(lái)做這個(gè)工作。