free在釋放內存的時候,為什么不需要指定內存的大小?
這個是學生前兩天面大疆的時候,面試官提出的問題。
這個問題不難,比起malloc申請內存的過程要簡單的多。
malloc在申請內存的時候,需要指定內存的大小,申請成功則返回這塊內存的地址,但是free的時候,只需要指定釋放的內存的起始地址,系統就知道從這個地址開始需要釋放多少個字節。
char*ptr = (char *)malloc(128); free(ptr);原因也很簡單,malloc在申請內存的時候,申請到的內存往往比我們需要的內存大,也就是在我們能使用的內存前面會多出一塊內存存放頭部信息,這個信息就包含了接下來這塊內存的大小。

所以在釋放內存的時候,只要根據我們提供的地址,向前再移動一些字節,就能知道需要釋放的內存大小。
《unix環境高級編程》一書中也提到:
大多數實現所分配的存儲空間比所要求的要稍大一些,額外的空間用來記錄管理信息——分配塊的長度,指向下一個分配塊的指針等等。
當然,這個所謂的頭部信息,不同的平臺存放的內容也不太一樣。
《C程序設計語言》這本書中就提到了一種結構:
union header_t { struct { unsigned size; unionheader_t*next; }; long align; };聯合體中嵌套了結構體,結構體中包含了兩個成員:一個是指向下一個頭部的指針,一個表示堆內存的大小。
寫個代碼驗證一下。
char*ptr=(char*)malloc(128); memset(ptr - 16, 0, 16); free(ptr);先用malloc申請一塊內存,然后從返回的地址開始,向前16個字節,全部清空成0,然后再用free釋放內存。
編譯沒有問題,但是運行的時候,提示free出錯。 這只是個演示代碼,實際情況不一定是16個字節。
所以在寫代碼的時候,一定不要越界訪問,一旦出了問題,很難去定位問題的出處。
審核編輯:劉清
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
C語言
+關注
關注
180文章
7630瀏覽量
140752
原文標題:free()為什么不需要指定內存大小
文章出處:【微信號:學益得智能硬件,微信公眾號:學益得智能硬件】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
熱點推薦
Linux內存系統: Linux 內存分配算法
, kmem_cache_free() 在其參數所指定的高速緩存中釋放一個 slab9、內核態內存池1) 基本原理· 先申請分配一定數量的、大小
發表于 08-24 07:44
使用malloc()和 free()函數動態的分配/釋放內存的危害
前言本文會從以下幾個方面闡述使用malloc()和 free()函數動態的分配/釋放內存的危害。存在的問題在嵌入式中無法很難實現對內存的動態映射(虛擬
發表于 12-14 07:56
可以使用malloc()和free()這兩個函數動態分配內存和釋放內存嗎
在ANSI C中,可以使用malloc()和free()這兩個函數動態分配內存和釋放內存,但是,在
發表于 12-17 08:26
使用rt_free釋放內存時出現to free a bad data block:的錯誤是為什么?
最近在使用rt_free釋放內存時會出現to free a bad data block:的錯誤。期初懷疑重復釋放
發表于 03-17 09:24
請教內存的釋放是否是在rt_free后就完成呢
問題描述:1.在線程中調用了一個函數A,該函數會申請內存函數結束前會再釋放。測試中發現這個函數在線程中調用幾次后就提示異常,申請不到內存。2:請教:內存的
發表于 08-29 11:41
LINUX內核中的內存是如何進行分配的
size);size:待分配的內存的大小,自動按頁對齊。默認在動態內存映射區分配。分配的內存在內核空間中連續(虛擬連續),物理上無需連續。
發表于 11-04 14:46
基于SLUB的DEBUG功能,如何幫忙檢測內存越界和訪問已經釋放的內存
SLAB內存分配器-SLUB的DEBUG功能,如何幫忙檢測內存越界(out-of-bounds)和訪問已經釋放的內存(use-after-free

STM32內存管理
內存管理詳解1、介紹內存管理,是指軟件運行時對計算機內存資源的分配和使用的技術。其最主要的目的是如何高效,快速的分配,并且在適當的時候
發表于 12-24 19:37
?14次下載

realloc函數和free函數的實驗及注意事項
拷貝到新分配的內存區域,而后釋放原來 mem_address 所指內存區域(注意:原來指針是自動釋放,不需要使用
內存釋放free步驟
內存釋放free Public_fREe() void public_fREe (Void_t* mem) { mstate ar_ptr;
評論