>백엔드 개발 >PHP 튜토리얼 >PHP 소스 코드 32에 대한 간략한 논의: PHP 메모리 풀의 emalloc/efree 계층 및 힙 계층

PHP 소스 코드 32에 대한 간략한 논의: PHP 메모리 풀의 emalloc/efree 계층 및 힙 계층

不言
不言원래의
2018-06-29 09:54:522027검색

이 글에서는 주로 PHP 소스 코드 32: Emalloc/efree 레이어와 PHP 메모리 풀의 힙 레이어에 대해 소개합니다. 이제는 필요한 모든 사람과 친구들과 공유할 수 있습니다. 🎜🎜#

PHP 소스 코드 32에 대한 간략한 설명: PHP 메모리 풀의 emalloc/efree 계층 및 힙 계층

emalloc/efree 계층은 전체 메모리 시스템의 최상위 구조입니다. 힙 레이어와의 교환을 통한 PHP 고유의 메모리 관리 메커니즘입니다. USE_ZEND_ALLOC을 0으로 설정하면 malloc/free 등의 함수를 이용하여 메모리를 직접 운용할 수 있다.
여기에서는 emalloc/efree 계층과 힙 계층 간의 상호 작용을 분석하고, emalloc 및 efree 함수 구현을 통해 힙 계층의 메모리 관리 메커니즘을 분석합니다.

【emaloc】

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)보다 작거나 크거나 같은 경우, free_buckets를 검색하여 적합한 메모리 블록이 있는지 확인합니다. 그렇지 않으면 zend_mm_search_large_block ()### ####[emalloc () -& gt; 적합한 Large_free_buckets 메모리 블록. ZEND_MM_LARGE_BUCKET_INDEX(true_size) 크기를 찾을 수 없는 경우 더 큰 블록 목록에서 가장 작은 블록을 찾아야 합니다.


대형 블록 목록과 소형 블록 목록 모두에서 발견되지 않으면 나머지 목록 블록에서 검색해야 합니다. 발견되면 zend_mm_finished_searching_for_block

그것도 점프합니다. 3개의 목록에 없습니다. 발견되면 메모리를 다시 할당해야 합니다. 이때 할당을 위해서는 저장계층의 할당함수를 호출한다. 할당할 메모리의 크기가 block_size보다 크면 그 크기를 기준으로 다시 계산해야 한다. 직접 할당됩니다.

메모리를 할당한 후에는 힙을 재정렬해야 합니다. 이때 힙의 메모리 크기를 다시 계산해야 하며 새로 할당된 메모리가 세그먼트 목록 앞에 추가됩니다.

위 작업에서 zend_mm_finished_searching_for_block으로 직접 점프하는 경우 해당 목록에서 사용된 메모리 블록을 제거해야 합니다(이것은 마킹 프로세스, 의사 제거여야 함)


다음에는 남은 메모리 양에 따라 여유 목록이나 남은 목록으로 이동합니다.

드디어 할당된 블록을 반환합니다.

emalloc의 전 과정에서 주의할 점이 있습니다.

ZEND_MM_BUCKET_INDEX(true_size)는 버킷의 위치에 위치합니다. 이 값은 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 소스 코드 31에 대한 간략한 토론: PHP 메모리 풀의 힙 계층 기본 사항

#🎜🎜 #

PHP 소스 코드 30에 대한 간략한 토론: PHP 메모리 풀의 저장 계층

PHP 소스 코드 29에 대한 간략한 토론: 인터페이스 상속에 대하여

위 내용은 PHP 소스 코드 32에 대한 간략한 논의: PHP 메모리 풀의 emalloc/efree 계층 및 힙 계층의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.