이 글의 내용은 PHP7 Kernel Analysis 7의 Zend 엔진 실행 과정에 대한 내용입니다. 이제 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다
1.EG (executor_globals/zend_executor_globals)
PHP 평생 Cycle에서 가장 중요한 구조는 기본 실행 전에 할당되는 전역 변수입니다(ZTS 아래 아님). PHP가 종료될 때까지 현재 요청의 모든 정보를 기록합니다
2. EX(execute_data/zend_execute_data)
는 실행 프로세스의 핵심 구조입니다. 각 함수 호출, include/require, eval 등은 현재 범위, 코드 실행 위치 및 지역 변수를 나타내는 새로운 구조를 생성합니다. 자,
#define EX(element) ((execute_data)->element) struct _zend_execute_data { const zend_op *opline; //指向当前执行的opcode,初始时指向zend_op_array起始位置 zend_execute_data *call; /* current call */ zval *return_value; //返回值指针 zend_function *func; //当前执行的函数(非函数调用时为空) zval This; //这个值并不仅仅是面向对象的this,还有另外两个值也通过这个记录:call_info + num_args,分别存在zval.u1.reserved、zval.u2.num_args zend_class_entry *called_scope; //当前call的类 zend_execute_data *prev_execute_data; //函数调用时指向调用位置作用空间 zend_array *symbol_table; //全局变量符号表 #if ZEND_EX_USE_RUN_TIME_CACHE void **run_time_cache; /* cache op_array->run_time_cache */ #endif #if ZEND_EX_USE_LITERALS zval *literals; //字面量数组,与func.op_array->literals相同 #endif };
3. Zend의 실행 프로세스
Zend VM에서 zend_execute_data.opline, zend_execute_data.prev_execute_data는 call/ret
step1: 为当前作用域分配一块内存,充当运行栈,zend_execute_data结构、所有局部变量、中间变量等等都在此内存上分配 step2: 初始化全局变量符号表,然后将全局执行位置指针EG(current_execute_data)指向step1新分配的zend_execute_data,然后将zend_execute_data.opline指向op_array的起始位置 step3: 从EX(opline)开始调用各opcode的C处理handler(即_zend_op.handler),每执行完一条opcode将EX(opline)++继续执行下一条,直到执行完全部opcode,函数/类成员方法调用、if的执行过程: step3.1: if语句将根据条件的成立与否决定EX(opline) + offset所加的偏移量,实现跳转 step3.2: 如果是函数调用,则首先从EG(function_table)中根据function_name取出此function对应的编译完成的zend_op_array,然后像step1一样新分配一个zend_execute_data结构, 将EG(current_execute_data)赋值给新结构的prev_execute_data,再将EG(current_execute_data)指向新的zend_execute_data,最后从新的zend_execute_data.opline开始执行,切换 到函数内部,函数执行完以后将EG(current_execute_data)重新指向EX(prev_execute_data),释放分配的运行栈,销毁局部变量,继续从原来函数调用的位置执行 step4: 全部opcode执行完成后将step1分配的内存释放,这个过程会将所有的局部变量"销毁",执行阶段结束
를 구현합니다.
4. 런타임 캐시
실행 중에 PHP는 이름을 기반으로 다양한 해시 테이블에서 상수, 함수, 클래스, 멤버 메서드, 멤버 속성 등을 검색해야 하는 경우가 많으므로 이 캐싱 메커니즘은 다음과 같은 용도로 사용됩니다. 이름을 기준으로 찾은 결과를 캐시하여 동일한 opcode가 다시 실행될 때 반복 검색 없이 마지막으로 캐시된 값을 바로 재사용할 수 있어 실행 효율성이 향상됩니다. 런타임 캐싱 메커니즘은 동일한 opcode가 여러 번 실행되는 경우에만 적용됩니다. 여기서 동일한 opcode는 동일한 opcode 값을 참조하지 않지만 실제로 런타임 캐시는 메모리의 동일한 데이터를 기반으로 합니다. opcode의 CONST 피연산자는 저장됩니다. 즉, IS_CONST 유형을 포함하는 피연산자만 이 메커니즘을 사용할 수 있으며 다른 유형은 사용되지 않습니다. 이는 CONST 피연산자만 고정되고 다른 CV, VAR 및 기타 유형은 사용되지 않기 때문입니다. 값 유형은 고정되지 않으므로 캐시된 값은 고정되지 않으므로 CONST 이외의 유형의 opcode 작업은 캐시되지 않습니다.PHP7 커널 분석 6개 함수
PHP7 커널 분석 4개 지역 변수, 전역 변수, 상수
위 내용은 PHP7 커널 분석 7 Zend 엔진 실행 프로세스의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!