使用remalloc的注意事項說明(必看篇)
原型:extern void *realloc(void *mem_address, unsigned int newsize);
用法:#include <malloc.h>
功能:改變mem_address所指內存區(qū)域的大小為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()試圖直接從堆上現(xiàn)存的數據后面的那些字節(jié)中獲得附加的字節(jié),如果能夠滿足,自然天下太平;可如果數據后面的字節(jié)不夠的話,那么就使用堆上第一個有足夠大小的自由塊,現(xiàn)存的數據然后就被拷貝至新的位置,而老塊則放回到堆上。返回值指向新分配的內存地址。
由于在這其中可能會發(fā)生數據的移動,因此我們應該盡力避免下面的用法。
…………………………
#include <malloc.h> char *p,*q; p = (char * ) malloc (10); q=p; p = (char * ) realloc (p,20);
…………………………
在這種情況下,如果發(fā)生了數據的移動,p指向了新分配的內存地址,但是指針q還依然指向原先的內存地址,而原先的那部分內存已經在realloc函數中free掉了,因此指針q成了“野指針”,指向了一塊未知的內存區(qū)域,這是很危險的。類似的,我們也應該盡量避免下面這種情況的使用。
…………………………
q = (char * ) realloc (p,20);
………………………
與第一種情況類似,如果發(fā)生了數據的移動,q指向了新分配的內存地址,而指針p還依然指向原先的內存地址,此時p成了野指針。如果不得以非得這樣使用的話(估計這種情況是不存在的),我們也應該緊跟此后將指針p置為NULL。
…………………………
q = (char * ) realloc (p,20); p = NULL;
以上這篇使用remalloc的注意事項說明(必看篇)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
C++實現(xiàn)八個常用的排序算法 插入排序、冒泡排序、選擇排序、希爾排序等
這篇文章主要介紹了C++如何實現(xiàn)八個常用的排序算法:插入排序、冒泡排序、選擇排序、希爾排序 、快速排序、歸并排序、堆排序和LST基數排序,需要的朋友可以參考下2015-07-07