使用remalloc的注意事項說明(必看篇)。本站提示廣大學習愛好者:(使用remalloc的注意事項說明(必看篇))文章只能為提供參考,不一定能成為您想要的結果。以下是使用remalloc的注意事項說明(必看篇)正文
原型:extern void *realloc(void *mem_address, unsigned int newsize);
用法:#include <malloc.h>
功能:改變mem_address所指內存區域的大小為newsize長度。
說明:如果重新分配成功則返回指向被分配內存的指針,否則返回空指針NULL。當內存不再使用時,應使用free()函數將內存塊釋放。
下面再看MSDN中對realloc()函數的描述:
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()函數的返回值是void *型的。
有下面三種情況:
1、返回void * 指針,調用成功。Void *型的指針指向新分配的內存空間。在需要的情況下可以再對這個指針進行強制類型轉換,轉換成你需要的類型的指針。如果傳入的第一個指針參數為NULL,則該函數等同與malloc函數。
2、返回NULL,當需要擴展的大小(第二個參數)為0並且第一個參數不為NULL,此時原內存被“freed”掉了。
我們知道,realloc是從堆上分配內存的,當擴大一塊內存空間時, realloc()試圖直接從堆上現存的數據後面的那些字節中獲得附加的字節,如果能夠滿足,自然天下太平;可如果數據後面的字節不夠的話,那麼就使用堆上第一個有足夠大小的自由塊,現存的數據然後就被拷貝至新的位置,而老塊則放回到堆上。返回值指向新分配的內存地址。
由於在這其中可能會發生數據的移動,因此我們應該盡力避免下面的用法。
…………………………
#include <malloc.h> char *p,*q; p = (char * ) malloc (10); q=p; p = (char * ) realloc (p,20);
…………………………
在這種情況下,如果發生了數據的移動,p指向了新分配的內存地址,但是指針q還依然指向原先的內存地址,而原先的那部分內存已經在realloc函數中free掉了,因此指針q成了“野指針”,指向了一塊未知的內存區域,這是很危險的。類似的,我們也應該盡量避免下面這種情況的使用。
…………………………
q = (char * ) realloc (p,20);
………………………
與第一種情況類似,如果發生了數據的移動,q指向了新分配的內存地址,而指針p還依然指向原先的內存地址,此時p成了野指針。如果不得以非得這樣使用的話(估計這種情況是不存在的),我們也應該緊跟此後將指針p置為NULL。
…………………………
q = (char * ) realloc (p,20); p = NULL;
以上這篇使用remalloc的注意事項說明(必看篇)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。