淺談PHP源碼三十二:PHP內存池中的emalloc/efree層與堆(heap)層
emalloc/efree層是整個內存體系中最上層結構,它通過與堆層的交換使用PHP自帶的內存管理機制。如果有設置USE_ZEND_ALLOC為0,則直接使用malloc/free等函數直接操作內存。
這里將從emalloc與efree兩個函數的實現解析emalloc/efree層與堆層的交互,及堆層對于內存的管理機制。
【emalloc】
emalloc函數是從zend_alloc.h 70行開始。
emalloc是一個宏,其對應了_emalloc函數。
在_emalloc函數中,如果未使用zend的內存管理機制,則直接調用malloc函數,否則調用
_zend_mm_alloc_int[emalloc() - _emalloc() - _zend_mm_alloc_int() ]
在_zend_mm_alloc_int函數中,程序會處理真實需要的內存小于或大于等于ZEND_MM_MAX_SMALL_SIZE(272)兩種情況,如果小于ZEND_MM_MAX_SMALL_SIZE,則會搜索free_buckets,看是否有合適的內存塊,如果可以在free_buckets中找到合適的塊使用,同直接跳轉到zend_mm_finished_searching_for_block,否則執行zend_mm_search_large_block()
[emalloc() - _emalloc() - _zend_mm_alloc_int() - zend_mm_search_large_block()]
zend_mm_search_large_block函數用來在large_free_buckets中查找合適的內存塊。其中當對于ZEND_MM_LARGE_BUCKET_INDEX(true_size)大小的沒有找到時,需要查找更大塊列表中的最小塊。
如果在大塊列表和小塊列表中都沒有,則需要從剩余列表塊中查找,如果找到,則同樣跳轉到zend_mm_finished_searching_for_block
如果三個列表中都沒有找到,則需要重新增加內存分配。此時調用storage層的分配函數進行分配,其中內存的大小,如果需要分配的內存大于block_size,則需要根據大小重新計算,否則直接分配block_size大小的內存。
分配內存完后,需要重新整理堆,此時需要重新計算堆中的內存大小,將新分配的內存添加到segments_list的前面。
如果在上面的操作中是直接跳轉到zend_mm_finished_searching_for_block,則需要將使用了的內存塊從對應的列表中移除(此處應該是一個標記的過程,偽移除)
接下來,根據剩下的內存大小,將其移到空閑列表或剩余列表。
最后返回分配的塊。
在emalloc整個過程中,有以下一些注意點。
ZEND_MM_BUCKET_INDEX(true_size)定位在bucket中的位置,這個值大于等于0,小于32。
其實現如下:
#define ZEND_MM_BUCKET_INDEX(true_size) ((true_size ZEND_MM_ALIGNMENT_LOG2)-(ZEND_MM_ALIGNED_MIN_HEADER_SIZE ZEND_MM_ALIGNMENT_LOG2))
free_bitmap和large_free_bitmap的值都是0到31。
【efree】
efree函數是從zend_alloc.h 72行開始。
efree是一個宏,其對應了_efree函數。
在_efree函數中,如果未使用zend的內存管理機制,則直接調用free函數,否則調用_
zend_mm_free_int[efree() - _efree() - _zend_mm_free_int() ]
堆首先將整個堆的大小減少,如果當前塊的后一個塊是空閑塊,則將后一個空閑塊從空閑塊列表中刪除并與當前塊合并,如果當前塊的前一個塊是空閑塊,則將前一個空閑塊從空閑塊列表中刪除并與當前塊合并,指針指向前一個空閑塊。如果此時當前塊是開始的塊,則調用zend_mm_del_segment將整段內存清除,如果不是開始塊,則將合并后的塊添加到空閑塊列表。
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP !
相關推薦:
淺談PHP源碼三十一:PHP內存池中的堆(heap)層基礎
淺談PHP源碼三十:PHP內存池中的存儲層
淺談PHP源碼二十九:關于接口的繼承
以上就是淺談PHP源碼三十二:PHP內存池中的emalloc/efree層與堆(heap)層的詳細內容,PHP教程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答