您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關使用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的注意事項有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。