0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

free在釋放內(nèi)存的時候,為什么不需要指定內(nèi)存的大?。?/h1>

free在釋放內(nèi)存的時候,為什么不需要指定內(nèi)存的大???

這個是學(xué)生前兩天面大疆的時候,面試官提出的問題。

這個問題不難,比起malloc申請內(nèi)存的過程要簡單的多。

malloc在申請內(nèi)存的時候,需要指定內(nèi)存的大小,申請成功則返回這塊內(nèi)存的地址,但是free的時候,只需要指定釋放的內(nèi)存的起始地址,系統(tǒng)就知道從這個地址開始需要釋放多少個字節(jié)。

char*ptr = (char *)malloc(128);
free(ptr);
原因也很簡單,malloc在申請內(nèi)存的時候,申請到的內(nèi)存往往比我們需要的內(nèi)存大,也就是在我們能使用的內(nèi)存前面會多出一塊內(nèi)存存放頭部信息,這個信息就包含了接下來這塊內(nèi)存的大小。

be51b88e-53a6-11ee-a25d-92fbcf53809c.png ?

所以在釋放內(nèi)存的時候,只要根據(jù)我們提供的地址,向前再移動一些字節(jié),就能知道需要釋放的內(nèi)存大小。

《unix環(huán)境高級編程》一書中也提到:

大多數(shù)實現(xiàn)所分配的存儲空間比所要求的要稍大一些,額外的空間用來記錄管理信息——分配塊的長度,指向下一個分配塊的指針等等。

當(dāng)然,這個所謂的頭部信息,不同的平臺存放的內(nèi)容也不太一樣。

《C程序設(shè)計語言》這本書中就提到了一種結(jié)構(gòu):

union header_t
{
  struct 
  {
     unsigned size;
unionheader_t*next;
  };


  long align;
};
聯(lián)合體中嵌套了結(jié)構(gòu)體,結(jié)構(gòu)體中包含了兩個成員:一個是指向下一個頭部的指針,一個表示堆內(nèi)存的大小。

寫個代碼驗證一下。
char*ptr=(char*)malloc(128);
memset(ptr - 16, 0, 16);
free(ptr);
先用malloc申請一塊內(nèi)存,然后從返回的地址開始,向前16個字節(jié),全部清空成0,然后再用free釋放內(nèi)存。

編譯沒有問題,但是運行的時候,提示free出錯。 這只是個演示代碼,實際情況不一定是16個字節(jié)。

所以在寫代碼的時候,一定不要越界訪問,一旦出了問題,很難去定位問題的出處。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7581

    瀏覽量

    135555

原文標(biāo)題:free()為什么不需要指定內(nèi)存大小

文章出處:【微信號:學(xué)益得智能硬件,微信公眾號:學(xué)益得智能硬件】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    linux的內(nèi)存釋放操作

    Linux系統(tǒng)下,我們一般不需要釋放內(nèi)存,因為系統(tǒng)已經(jīng)將內(nèi)存管理的很好。但是凡事也有例外,有的時候
    發(fā)表于 07-26 07:05

    Linux內(nèi)存系統(tǒng): Linux 內(nèi)存分配算法

    , kmem_cache_free() 在其參數(shù)所指定的高速緩存中釋放一個 slab9、內(nèi)核態(tài)內(nèi)存池1) 基本原理· 先申請分配一定數(shù)量的、大小
    發(fā)表于 08-24 07:44

    【原創(chuàng)】堆內(nèi)存的那些事

    時候,根據(jù)指針指向的堆內(nèi)存區(qū)域的情況和指針大小重新分配內(nèi)存。對于realloc()作為重新分配內(nèi)存
    發(fā)表于 07-12 09:48

    使用malloc()和 free()函數(shù)動態(tài)的分配/釋放內(nèi)存的危害

    前言本文會從以下幾個方面闡述使用malloc()和 free()函數(shù)動態(tài)的分配/釋放內(nèi)存的危害。存在的問題在嵌入式中無法很難實現(xiàn)對內(nèi)存的動態(tài)映射(虛擬
    發(fā)表于 12-14 07:56

    可以使用malloc()和free()這兩個函數(shù)動態(tài)分配內(nèi)存釋放內(nèi)存

    ANSI C中,可以使用malloc()和free()這兩個函數(shù)動態(tài)分配內(nèi)存釋放內(nèi)存,但是,
    發(fā)表于 12-17 08:26

    使用rt_free釋放內(nèi)存時出現(xiàn)to free a bad data block:的錯誤是為什么?

    最近在使用rt_free釋放內(nèi)存時會出現(xiàn)to free a bad data block:的錯誤。期初懷疑重復(fù)釋放
    發(fā)表于 03-17 09:24

    請教內(nèi)存釋放是否是rt_free后就完成呢

    問題描述:1.在線程中調(diào)用了一個函數(shù)A,該函數(shù)會申請內(nèi)存函數(shù)結(jié)束前會再釋放。測試中發(fā)現(xiàn)這個函數(shù)在線程中調(diào)用幾次后就提示異常,申請不到內(nèi)存。2:請教:內(nèi)存
    發(fā)表于 08-29 11:41

    LINUX內(nèi)核中的內(nèi)存是如何進(jìn)行分配的

    size);size:待分配的內(nèi)存大小,自動按頁對齊。默認(rèn)動態(tài)內(nèi)存映射區(qū)分配。分配的內(nèi)存在內(nèi)核空間中連續(xù)(虛擬連續(xù)),物理上無需連續(xù)。
    發(fā)表于 11-04 14:46

    如何在Win 2003中安全的釋放內(nèi)存

    如何在Win 2003中安全的釋放內(nèi)存 經(jīng)??吹接信笥?b class='flag-5'>在論壇上訴苦說需要釋放內(nèi)存,其實如果你安
    發(fā)表于 01-29 11:36 ?671次閱讀

    基于SLUB的DEBUG功能,如何幫忙檢測內(nèi)存越界和訪問已經(jīng)釋放內(nèi)存

    SLAB內(nèi)存分配器-SLUB的DEBUG功能,如何幫忙檢測內(nèi)存越界(out-of-bounds)和訪問已經(jīng)釋放內(nèi)存(use-after-free
    的頭像 發(fā)表于 02-08 14:11 ?9494次閱讀
    基于SLUB的DEBUG功能,如何幫忙檢測<b class='flag-5'>內(nèi)存</b>越界和訪問已經(jīng)<b class='flag-5'>釋放</b>的<b class='flag-5'>內(nèi)存</b>

    Android內(nèi)存管理機制與分析工具

    Android 系統(tǒng)中有個垃圾內(nèi)存回收機制,虛擬機層自動分配和釋放內(nèi)存,因此不需要在代碼中
    的頭像 發(fā)表于 05-11 14:44 ?4503次閱讀

    STM32內(nèi)存管理

    內(nèi)存管理詳解1、介紹內(nèi)存管理,是指軟件運行時對計算機內(nèi)存資源的分配和使用的技術(shù)。其最主要的目的是如何高效,快速的分配,并且適當(dāng)?shù)?b class='flag-5'>時候
    發(fā)表于 12-24 19:37 ?13次下載
    STM32<b class='flag-5'>內(nèi)存</b>管理

    malloc和free簡介及實現(xiàn)方式說明

    malloc 分配指定大小內(nèi)存空間,返回一個指向該空間的指針。大小以字節(jié)為單位。返回 void* 指針,需要強制類型轉(zhuǎn)換后才能引用其中的值
    的頭像 發(fā)表于 05-14 09:56 ?4475次閱讀
    malloc和<b class='flag-5'>free</b>簡介及實現(xiàn)方式說明

    realloc函數(shù)和free函數(shù)的實驗及注意事項

    拷貝到新分配的內(nèi)存區(qū)域,而后釋放原來 mem_address 所指內(nèi)存區(qū)域(注意:原來指針是自動釋放,不需要使用
    的頭像 發(fā)表于 10-21 16:51 ?649次閱讀

    內(nèi)存釋放free步驟

    內(nèi)存釋放free Public_fREe() void public_fREe (Void_t* mem) { mstate ar_ptr;
    的頭像 發(fā)表于 11-09 11:31 ?737次閱讀