使用remalloc的注意事項說明(必看篇)
原型:extern void *realloc(void *mem_address, unsigned int newsize);
用法:#include <malloc.h>
功能:改變mem_address所指內(nèi)存區(qū)域的大小為newsize長度。
說明:如果重新分配成功則返回指向被分配內(nèi)存的指針,否則返回空指針NULL。當(dāng)內(nèi)存不再使用時,應(yīng)使用free()函數(shù)將內(nèi)存塊釋放。
下面再看MSDN中對realloc()函數(shù)的描述:
realloc returns a void pointer to the reallocated (and possibly moved) memory block. The return value is NULL if the size is zero and the buffer argument is not NULL, or if there is not enough available memory to expand the block to the given size. In the first case, the original block is freed. In the second, the original block is unchanged. The return value points to a storage space that is guaranteed to be suitably aligned for storage of any type of object. To get a pointer to a type other than void, use a type cast on the return value.
這段E文基本上是在講realloc()的返回值的。realloc()函數(shù)的返回值是void *型的。
有下面三種情況:
1、返回void * 指針,調(diào)用成功。Void *型的指針指向新分配的內(nèi)存空間。在需要的情況下可以再對這個指針進行強制類型轉(zhuǎn)換,轉(zhuǎn)換成你需要的類型的指針。如果傳入的第一個指針參數(shù)為NULL,則該函數(shù)等同與malloc函數(shù)。
2、返回NULL,當(dāng)需要擴展的大?。ǖ诙€參數(shù))為0并且第一個參數(shù)不為NULL,此時原內(nèi)存被“freed”掉了。
我們知道,realloc是從堆上分配內(nèi)存的,當(dāng)擴大一塊內(nèi)存空間時, realloc()試圖直接從堆上現(xiàn)存的數(shù)據(jù)后面的那些字節(jié)中獲得附加的字節(jié),如果能夠滿足,自然天下太平;可如果數(shù)據(jù)后面的字節(jié)不夠的話,那么就使用堆上第一個有足夠大小的自由塊,現(xiàn)存的數(shù)據(jù)然后就被拷貝至新的位置,而老塊則放回到堆上。返回值指向新分配的內(nèi)存地址。
由于在這其中可能會發(fā)生數(shù)據(jù)的移動,因此我們應(yīng)該盡力避免下面的用法。
…………………………
#include <malloc.h> char *p,*q; p = (char * ) malloc (10); q=p; p = (char * ) realloc (p,20);
…………………………
在這種情況下,如果發(fā)生了數(shù)據(jù)的移動,p指向了新分配的內(nèi)存地址,但是指針q還依然指向原先的內(nèi)存地址,而原先的那部分內(nèi)存已經(jīng)在realloc函數(shù)中free掉了,因此指針q成了“野指針”,指向了一塊未知的內(nèi)存區(qū)域,這是很危險的。類似的,我們也應(yīng)該盡量避免下面這種情況的使用。
…………………………
q = (char * ) realloc (p,20);
………………………
與第一種情況類似,如果發(fā)生了數(shù)據(jù)的移動,q指向了新分配的內(nèi)存地址,而指針p還依然指向原先的內(nèi)存地址,此時p成了野指針。如果不得以非得這樣使用的話(估計這種情況是不存在的),我們也應(yīng)該緊跟此后將指針p置為NULL。
…………………………
q = (char * ) realloc (p,20); p = NULL;
以上這篇使用remalloc的注意事項說明(必看篇)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
C++實現(xiàn)八個常用的排序算法 插入排序、冒泡排序、選擇排序、希爾排序等
這篇文章主要介紹了C++如何實現(xiàn)八個常用的排序算法:插入排序、冒泡排序、選擇排序、希爾排序 、快速排序、歸并排序、堆排序和LST基數(shù)排序,需要的朋友可以參考下2015-07-07