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