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

C語言基礎(chǔ)之malloc和free函數(shù)詳解

 更新時間:2017年04月10日 17:11:45   投稿:lqh  
這篇文章主要介紹了C語言基礎(chǔ)之malloc和free函數(shù)詳解的相關(guān)資料,需要的朋友可以參考下

    本文介紹malloc和free函數(shù)的內(nèi)容。

  在C中,對內(nèi)存的管理是相當(dāng)重要。下面開始介紹這兩個函數(shù):

  一、malloc()和free()的基本概念以及基本用法:

1、函數(shù)原型及說明:

void *malloc(long NumBytes):該函數(shù)分配了NumBytes個字節(jié),并返回了指向這塊內(nèi)存的指針。如果分配失敗,則返回一個空指針(NULL)。

關(guān)于分配失敗的原因,應(yīng)該有多種,比如說空間不足就是一種。

void free(void *FirstByte): 該函數(shù)是將之前用malloc分配的空間還給程序或者是操作系統(tǒng),也就是釋放了這塊內(nèi)存,讓它重新得到自由。

2、函數(shù)的用法:

     其實這兩個函數(shù)用起來倒不是很難,也就是malloc()之后覺得用夠了就甩了它把它給free()了,舉個簡單例子:

程序代碼:       

 // Code... 
  char *Ptr = NULL; 
  Ptr = (char *)malloc(100 * sizeof(char)); 
  if (NULL == Ptr) 
   { 
     exit (1); 
   } 
  gets(Ptr); 

  // code... 
  free(Ptr); 
  Ptr = NULL; 
  // code...

就是這樣!當(dāng)然,具體情況要具體分析以及具體解決。比如說,你定義了一個指針,在一個函數(shù)里申請了一塊內(nèi)存然后通過函數(shù)返回傳遞給這個指針,那么也許釋放這塊內(nèi)存這項工作就應(yīng)該留給其他函數(shù)了。

3、關(guān)于函數(shù)使用需要注意的一些地方:

A、申請了內(nèi)存空間后,必須檢查是否分配成功。

B、當(dāng)不需要再使用申請的內(nèi)存時,記得釋放;釋放后應(yīng)該把指向這塊內(nèi)存的指針指向NULL,防止程序后面不小心使用了它。

C、這兩個函數(shù)應(yīng)該是配對。如果申請后不釋放就是內(nèi)存泄露;如果無故釋放那就是什么也沒有做。釋放只能一次,如果釋放兩次及兩次以上會

出現(xiàn)錯誤(釋放空指針例外,釋放空指針其實也等于啥也沒做,所以釋放空指針釋放多少次都沒有問題)。

D、雖然malloc()函數(shù)的類型是(void *),任何類型的指針都可以轉(zhuǎn)換成(void *),但是最好還是在前面進(jìn)行強(qiáng)制類型轉(zhuǎn)換,因為這樣可以躲過一些編譯器的檢查。

現(xiàn)在進(jìn)入第二部分:

   二、malloc()到底從哪里得來了內(nèi)存空間:

1、malloc()到底從哪里得到了內(nèi)存空間?答案是從堆里面獲得空間。也就是說函數(shù)返回的指針是指向堆里面的一塊內(nèi)存。操作系統(tǒng)中有一個記錄空閑內(nèi)存地址的鏈表。當(dāng)操作系統(tǒng)收到程序的申請時,就會遍歷該鏈表,然后就尋找第一個空間大于所申請空間的堆結(jié)點,然后就將該結(jié)點從空閑結(jié)點鏈表中刪除,并將該結(jié)點的空間分配給程序。關(guān)于堆的知識呢可以查詢數(shù)據(jù)結(jié)構(gòu)方面的知識或查詢以前的一篇帖子C/C++堆、棧及靜態(tài)數(shù)據(jù)區(qū)詳解。這里不過多介紹。

2、在使用malloc()分配內(nèi)存空間后,一定要記得釋放內(nèi)存空間,否則就會出現(xiàn)內(nèi)存泄漏。

3、free()到底釋放了什么

free()釋放的是指針指向的內(nèi)存!注意!釋放的是內(nèi)存,不是指針!指針并沒有被釋放,指針仍然指向原來的存儲空間。指針是一個變量,只有程序結(jié)束時才被銷毀。釋放了內(nèi)存空間后,原來指向這塊空間的指針還是存在!只不過現(xiàn)在指針指向的內(nèi)容的垃圾,是未定義的,所以說是垃圾。因此,釋放內(nèi)存后把指針指向NULL,防止指針在后面不小心又被解引用了。

   三、malloc()以及free()的機(jī)制:

事實上,仔細(xì)看一下free()的函數(shù)原型,也許也會發(fā)現(xiàn)似乎很神奇,free()函數(shù)非常簡單,只有一個參數(shù),只要把指向申請空間的指針傳遞給free()中的參數(shù)就可以完成釋放工作!這里要追蹤到malloc()的申請問題了。申請的時候?qū)嶋H上占用的內(nèi)存要比申請的大。因為超出的空間是用來記錄對這塊內(nèi)存的管理信息。

大多數(shù)實現(xiàn)所分配的存儲空間比所要求的要稍大一些,額外的空間用來記錄管理信息——分配塊的長度,指向下一個分配塊的指針等等。這就意味著如果寫過一個已分配區(qū)的尾端,則會改寫后一塊的管理信息。這種類型的錯誤是災(zāi)難性的,但是因為這種錯誤不會很快就暴露出來,所以也就很難發(fā)現(xiàn)。將指向分配塊的指針向后移動也可能會改寫本塊的管理信息。

malloc()申請的空間實際就是分了兩個不同性質(zhì)的空間。一個就是用來記錄管理信息的空間,另外一個就是可用空間了。而用來記錄管理信息的實際上是一個結(jié)構(gòu)體。在C語言中,經(jīng)常用結(jié)構(gòu)來記錄信息!下面看看這個結(jié)構(gòu)體的原型:

程序代碼:

 struct mem_control_block { 
 int is_available; //一般來說應(yīng)該是一個可用空間的首地址,但這里英文單詞卻顯示出空間是否可用的一個標(biāo)記
 int size;   //這是實際空間的大小 
 };

 

  所以,free()就是根據(jù)這個結(jié)構(gòu)體的信息來釋放malloc()申請的空間!而結(jié)構(gòu)體的兩個成員的大小我想應(yīng)該是操作系統(tǒng)的事了。
  下面看看free()的源代碼
   // code... 
 
  void free(void *ptr) 
 { 
   struct mem_control_block *free; 
   free = ptr - sizeof(struct mem_control_block); 
   free->is_available = 1; 
   return; 
 }

  至于malloc的源碼,有興趣的可以到網(wǎng)上找一下!

        感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • strtok函數(shù)的使用示例

    strtok函數(shù)的使用示例

    今天小編就為大家分享一篇關(guān)于strtok函數(shù)的使用示例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • 基于C++17實現(xiàn)的手寫線程池

    基于C++17實現(xiàn)的手寫線程池

    本文主要介紹了基于C++17實現(xiàn)的手寫線程池,自己實現(xiàn)了Any類,Semaphore類以及Result類的開發(fā),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • 利用Matlab制作環(huán)形相冊效果詳解

    利用Matlab制作環(huán)形相冊效果詳解

    這篇文章主要為大家介紹了如何利用Matlab制作出環(huán)形相冊的效果,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下
    2022-03-03
  • C++中模板(Template)詳解及其作用介紹

    C++中模板(Template)詳解及其作用介紹

    這篇文章主要介紹了C++中模板(Template)的詳解及其作用介紹,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 用c++實現(xiàn)x的y次冪的代碼

    用c++實現(xiàn)x的y次冪的代碼

    以下實例是對使用c++實現(xiàn)x的y次冪的解決方法進(jìn)行了介紹。需要的朋友參考下
    2013-05-05
  • C++詳解使用floor&ceil&round實現(xiàn)保留小數(shù)點后兩位

    C++詳解使用floor&ceil&round實現(xiàn)保留小數(shù)點后兩位

    這篇文章主要介紹了C++使用floor&ceil&round實現(xiàn)保留小數(shù)點后兩位的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • VS2022連接sqlserver數(shù)據(jù)庫教程

    VS2022連接sqlserver數(shù)據(jù)庫教程

    本文主要介紹了VS2022連接sqlserver數(shù)據(jù)庫教程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • C++中的static和const的關(guān)鍵字用法詳解

    C++中的static和const的關(guān)鍵字用法詳解

    這篇文章主要介紹了C++中的static和const的關(guān)鍵字用法詳解,這是一道經(jīng)常在面試中被問到的知識,本文給大家詳細(xì)介紹下,需要的朋友可以參考下
    2023-06-06
  • 如何在C++中建立一個順序表

    如何在C++中建立一個順序表

    在使用順序表之前,首先創(chuàng)建一個空的順序表,也就是初始化順序表。這里,在程序中只需設(shè)置順序表的結(jié)點數(shù)量ListLen為0即可。這樣,后面需要添加的數(shù)據(jù)元素將從順序表的第一個位置存儲
    2013-10-10
  • C語言從猜數(shù)字游戲中理解數(shù)據(jù)結(jié)構(gòu)

    C語言從猜數(shù)字游戲中理解數(shù)據(jù)結(jié)構(gòu)

    猜數(shù)字是興起于英國的益智類小游戲,起源于20世紀(jì)中期,一般由兩個人或多人玩,也可以由一個人和電腦玩。游戲規(guī)則為一方出數(shù)字,一方猜,今天我們來用這個游戲案例理解數(shù)據(jù)結(jié)構(gòu)
    2022-04-04

最新評論