>  기사  >  백엔드 개발  >  PHP 변수의 메모리 관리

PHP 변수의 메모리 관리

不言
不言원래의
2018-04-18 10:11:101893검색

이 기사에서는 특정 참조 값이 있는 PHP 변수의 메모리 관리를 주로 소개합니다. 이제 모든 사람과 공유합니다. 필요한 친구가 참조할 수 있습니다.

모든 컴퓨터 언어에는 변수 데이터를 저장하기 위한 컨테이너가 필요합니다. 일부 언어에서는 변수에 문자열, 배열, 객체 등과 같은 특정 유형이 있습니다. 예를 들어 C와 Pascal이 이 범주에 속합니다. PHP에는 그러한 유형이 없습니다. PHP에서는 한 줄의 문자열 변수가 다음 줄의 숫자가 될 수 있습니다. 변수는 자동으로라도 다른 유형 간에 쉽게 변환될 수 있는 경우가 많습니다. PHP가 단순하고 강력한 언어인 이유 중 가장 큰 이유는 약한 유형의 변수가 있기 때문입니다. 그러나 때로는 이로 인해 몇 가지 흥미로운 문제가 발생할 수 있습니다.

PHP 내부에서 변수는 zval이라는 컨테이너에 저장됩니다. 변수의 값뿐만 아니라 변수의 유형도 포함됩니다. PHP와 마찬가지로 Python에도 변수 유형을 표시하는 레이블이 있습니다. 변수 컨테이너에는 Zend 엔진이 참조 여부를 구별하는 데 사용하는 일부 필드가 포함되어 있습니다. 또한 이 값의 참조 횟수도 포함됩니다.

변수는 연관 배열과 동일한 기호 테이블에 저장됩니다. 이 배열은 변수 이름으로 키가 지정되며 이러한 변수가 포함된 컨테이너를 가리킵니다. 아래와 같이:


Reference Counting

PHP는 변수(예: $a = $b)를 복사할 때 현명하게 노력합니다. "="는 할당 연산자라고도 합니다. 할당 작업을 수행할 때 Zend 엔진은 새 변수 창을 생성하지 않지만 변수 창의 refcount 필드를 증가시킵니다. 이 변수가 거대한 문자열이거나 거대한 배열인 경우 메모리 양은 얼마나 될까요? 저장되었습니다. 아래 그림과 같이:


1단계: 변수 a에는 "this is"라는 텍스트가 포함되어 있습니다. 기본적으로 참조 횟수는 1

입니다. 2단계: 변수 $a를 $b 및 $c에 할당합니다. 여기에는 새로운 변수 컨테이너가 생성되지 않으며 변수가 할당될 때마다 refcount가 1씩 증가합니다. 여기서는 두 가지 할당 작업이 수행되므로 refcount는 결국 3이 됩니다.

이제 변수 $c가 변경되면 어떤 일이 일어날지 궁금할 것입니다. Refcount 값에 따라 두 가지 방식으로 처리됩니다. refcount가 1이면 변수 컨테이너는 해당 값(및 해당 유형도 업데이트)을 업데이트합니다. refcount가 1보다 크면 새 값(및 유형)을 포함하는 변수 컨테이너가 생성됩니다. 그림 2의 세 번째 단계에 표시된 것처럼 $a 변수가 위치한 변수 컨테이너의 refcount 값에서 1을 뺍니다. 이제 refcount 값은 2이고 새로 생성된 컨테이너의 refcount 값은 1입니다. unset 함수를 변수에 사용하면 그림의 4단계와 같이 변수가 위치한 컨테이너의 refcount 값이 1씩 감소합니다. refcount 값이 1보다 작으면 Zend 엔진은 그림의 5단계에 표시된 대로 변수 컨테이너를 변환합니다.

함수에 변수 전달

모든 스크립트가 공유하는 전역 기호 테이블 외에도 각 사용자 정의 함수는 자체 변수를 저장하기 위해 호출될 때 자체 기호 테이블을 생성합니다. 함수가 호출되면 Zend 엔진은 이러한 기호 테이블을 생성하고 함수 테이블은 함수가 반환될 때 해제됩니다. 함수는 return 문을 통해 반환되거나 함수가 끝나기 때문에 반환됩니다. (역자 주: 반환하지 않는 함수는 기본적으로 NULL을 반환합니다.) 아래 그림과 같이:


그림 3에서는 변수가 함수에 전달되는 방법을 자세히 설명합니다.

첫 번째 단계에서는 "thisis"를 변수 $a에 할당한 다음 이 변수를 do_something() 함수의 $s 변수에 전달합니다.

두 번째 단계에서는 다른 기호 테이블(함수 기호 테이블)에 저장된다는 점을 제외하면 변수 할당과 동일한 작업임을 알 수 있습니다(이전 섹션에서 언급한 $b = $a 와 유사). ) , 참조 횟수는 1이 아닌 2씩 증가합니다. 그 이유는 함수 스택에도 이 변수 ​​컨테이너에 대한 참조가 포함되어 있기 때문입니다.

세 번째 단계에서는 $s 변수에 새 값을 할당하면 원래 변수 컨테이너의 참조 횟수가 1만큼 줄어들고 새 값을 포함하는 변수 컨테이너가 생성됩니다.

네 번째 단계에서는 return 문을 통해 변수를 반환합니다. 반환된 변수는 전역 기호 테이블에서 엔터티를 가져오고 참조 개수를 1씩 증가시킵니다. 함수가 끝나면 함수의 기호 테이블이 삭제됩니다. 소멸 프로세스 동안 Zend 엔진은 기호 테이블의 각 변수를 탐색하고 해당 참조 카운트 값을 줄입니다. 변수 컨테이너의 리파운트 값이 0이 되면 변수 컨테이너는 소멸됩니다. 보시다시피, PHP의 참조 계산 메커니즘으로 인해 변수 컨테이너는 함수에서 복사되지 않습니다. $s 변수가 세 번째 단계에서 수정되지 않은 경우 $a 및 $b 변수는 항상 동일한 변수 컨테이너를 가리킵니다(이 컨테이너의 참조 개수는 2입니다). 이 경우 $a = "this is" 문은 변수 컨테이너의 복사본을 생성하지 않습니다.

관련 권장 사항:

php 변수 쓰기 시 복사 메커니즘


위 내용은 PHP 변수의 메모리 관리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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