欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用remalloc的注意事項說明(必看篇)

 更新時間:2017年03月28日 09:55:03   投稿:jingxian  
下面小編就為大家?guī)硪黄褂胷emalloc的注意事項說明(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

原型: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)車票管理系統(tǒng)

    C語言實現(xiàn)車票管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)車票管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 用C語言編寫推箱子游戲

    用C語言編寫推箱子游戲

    這篇文章主要為大家詳細介紹了用C語言編寫推箱子游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • C語言動態(tài)內存的分配實例詳解

    C語言動態(tài)內存的分配實例詳解

    動態(tài)內存管理同時還具有一個優(yōu)點,當程序在具有更多內存的系統(tǒng)上需要處理更多數據時,不需要重寫程序,下面這篇文章主要給大家介紹了關于C語言動態(tài)內存分配的相關資料,需要的朋友可以參考下
    2022-06-06
  • OpenCV基于背景減除實現(xiàn)行人計數

    OpenCV基于背景減除實現(xiàn)行人計數

    本文主要介紹了如何使用OpenCV C++對視頻中的人流量進行統(tǒng)計。文中的示例代碼講解詳細,對我們學習OpenCV有一定的幫助,需要的可以了解一下
    2022-01-01
  • C++ Boost EnableIf函數使用介紹

    C++ Boost EnableIf函數使用介紹

    Boost是為C++語言標準庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標準庫的后備,是C++標準化進程的開發(fā)引擎之一,是為C++語言標準庫提供擴展的一些C++程序庫的總稱
    2022-11-11
  • C++ cin輸入的多種方法詳解

    C++ cin輸入的多種方法詳解

    cin是C++編程語言中的標準輸入流對象,即stream類的對象。cin主要用于從標準輸入讀取數據,這里的標準輸入,指的是終端的鍵盤。接下來通過本文給大家分享C++ cin輸入的幾種方式,一起看看吧
    2021-09-09
  • C++實現(xiàn)八個常用的排序算法 插入排序、冒泡排序、選擇排序、希爾排序等

    C++實現(xiàn)八個常用的排序算法 插入排序、冒泡排序、選擇排序、希爾排序等

    這篇文章主要介紹了C++如何實現(xiàn)八個常用的排序算法:插入排序、冒泡排序、選擇排序、希爾排序 、快速排序、歸并排序、堆排序和LST基數排序,需要的朋友可以參考下
    2015-07-07
  • C語言實現(xiàn)對文件進行操作的示例詳解

    C語言實現(xiàn)對文件進行操作的示例詳解

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)對文件進行操作的相關知識,文中的示例代碼講解詳細,對我們學習C語言有一定的幫助,需要的可以參考一下
    2023-04-04
  • 詳解C++ bitset用法

    詳解C++ bitset用法

    這篇文章主要介紹了C++ bitset用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • C++設計模式之適配器模式(Adapter)

    C++設計模式之適配器模式(Adapter)

    這篇文章主要為大家詳細介紹了C++設計模式之適配器模式Adapter,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03

最新評論