Home > Backend Development > PHP Tutorial > PHP principle execution cycle example analysis

PHP principle execution cycle example analysis

墨辰丷
Release: 2023-03-29 11:20:01
Original
1782 people have browsed it

This article mainly introduces the in-depth understanding of the execution cycle of PHP principles, and briefly analyzes the relevant principles of the PHP program from editing to lexical analysis, syntax analysis and interpretation execution. Friends in need can refer to the following

PHP execution cycle, from the initial PHP script we wrote -> to the final script being executed -> getting the execution result, this process can actually be divided into the following stages:

First , Zend Engine (ZE), calls the lexical analyzer (generated by Lex, the source file is in Zend/zend_language_sanner.l), removes spaces and comments from the PHP source file we want to execute, and divides it into tokens one by one.

Then, ZE will forward the obtained token to the syntax analyzer (generated by yacc, the source file is in Zend/zend_language_parser.y), and generate opcodes one by one. The opcodes generally exist in the form of op array. It is the intermediate language for PHP execution.

Finally, ZE calls zend_executor to execute op array and output the results. (That is, convert the source file into machine language and then run it on a virtual machine.)

ZE is a virtual machine. It is precisely because of its existence that we can write PHP scripts without any need for Consider the type of operating system you are running on, this is why PHP is portable. ZE is a CISC (Complex Instruction Processor), which supports 150 instructions (specific instructions are in Zend/zend_vm_opcodes.h), including the simplest ZEND_ECHO (echo) to the complex ZEND_INCLUDE_OR_EVAL (include, require), All the PHP we write will eventually be processed into a sequence of these 150 instructions (op code), and will eventually be executed.

PHP is a scripting language, that is to say, the PHP code written by the user will eventually be interpreted and executed by the PHP interpreter. All PHP codes written will be translated into the PHP virtual machine ZE virtual instructions (OPCODES) to execute.

So what will our PHP script be "translated" into in the end? In other words, what does the op code look like? Opcode is an intermediate language compiled from PHP scripts.

There is already such a module in PECL, using the VLD (Vulcan Logic Dissassembler) module developed by Derick Rethans. You only need to download this module and load it into PHP, and you can get the result of script translation through simple settings.

Installation and application of VLD module:

[root@localhost software]# tar zxvf vld-0.9.1.tgz.gz
[root@localhost vld-0.9.1]# /usr/local/php/bin/phpize
[root@localhost vld-0.9.1]# ./configure --with-php-config=/usr/local/php/bin/php-config
[root@localhost vld-0.9.1]# make install //不需要make
Copy after login

Edit the php.ini file and activate the vld extension.

Example:

Create a file, such as: hello.php

<?php
  echo &#39;hello, world.&#39;;
?>
Copy after login

Execute:

[root@localhost html]# /usr/local/php/bin/php -dvld.active=1 hello.php
Branch analysis from position: 0
Return found
filename:    /var/www/html/hello.php
function name: (null)
number of ops: 3
compiled vars: none
line   # op              fetch     ext return operands
-------------------------------------------------------------------------------
  2   0 ECHO                           &#39;hello%2C+world.&#39;
  4   1 RETURN                          1
     2* ZEND_HANDLE_EXCEPTION
hello, world.
Copy after login

Watch another:

[root@localhost html]# vi vld.php
<?php
  $i = "This is a string";
  //I am comments
  echo $i. &#39; that has been echoed on screen&#39;;
?>
Copy after login

Execute:

[root@localhost html]# /usr/local/php/bin/php -dvld.active=1 vld.php
Branch analysis from position: 0
Return found
filename:    /var/www/html/vld.php
function name: (null)
number of ops: 5
compiled vars: !0 = $i
line   # op              fetch     ext return operands
-------------------------------------------------------------------------------
  3   0 ASSIGN                          !0, &#39;This+is+a+string&#39;
  7   1 CONCAT                      ~1  !0, &#39;+that+has+been+echoed+on+screen&#39;
     2 ECHO                           ~1
 10  3 RETURN                          1
     4* ZEND_HANDLE_EXCEPTION
This is a string that has been echoed on screen
Copy after login

Note: ZEND_HANDLE_EXCEPTION is the 149th instruction in Zend/zend_vm_opcodes.h

compiled vars: !0 = $i Here is the variable name "i" The variable is at !0 (*zval).
#0 Assign the string "this is a string" (ASSIGN) to !0
#1 String connection
#2 Display

These intermediate codes will be used by Zend VM (Zend virtual machine) is executed directly. The function actually responsible for execution is: zend_execute (zend_execute.h).

Summary: The above is the entire content of this article, I hope it will be helpful to everyone's study.

Related recommendations:

How to use PHP to implement regular capture of the URL in the page

Identity card verification based on PHP Code verification calculation method

Based on PHP using locking to realize the code grabbing function under concurrent circumstances

The above is the detailed content of PHP principle execution cycle example analysis. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template