亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

PHP內(nèi)核探索 —— PHP腳本的執(zhí)行細(xì)節(jié):PHP、C、匯編、機(jī)器碼

瀏覽:5日期:2022-09-16 13:13:50

眾所周知,計(jì)算機(jī)的CPU只能執(zhí)行二進(jìn)制的機(jī)器碼,每種CPU都有對(duì)應(yīng)的匯編語言,匯編語言編譯器將匯編語言翻譯成二進(jìn)制的機(jī)器語言,然后CPU開始執(zhí)行這些機(jī)器碼。匯編語言作為機(jī)器語言與程序設(shè)計(jì)者之間的一個(gè)層,給我們帶來了很多方便,程序員不需要用晦澀的01數(shù)字來書寫程序,當(dāng)然人們并不滿足這樣的一個(gè)進(jìn)步,于是在匯編語言之上又多了一個(gè)層——C語言,C語言更貼近人類熟悉的“自然語言”,程序設(shè)計(jì)者可以通過C語言編譯器將C源代碼文件編譯成目標(biāo)文件(二進(jìn)制文件,中間會(huì)先翻譯成匯編語言,然后由匯編語言生成機(jī)器碼),然后將各個(gè)目標(biāo)文件連接在一起就組成了一個(gè)可執(zhí)行文件。正如有人說過的一句名言“計(jì)算機(jī)科學(xué)領(lǐng)域的任何問題都可以通過增加一個(gè)間接的中間層來解決”(“Any problem in computer science can be solved by another layer of indirection.”) PHP語言就是在C語言之上的一個(gè)層,PHP引擎是由C語言來實(shí)現(xiàn)的,因此PHP語言這一個(gè)在C之上抽象出來的層使用起來比C更簡(jiǎn)單方便,入門門檻更低。

那么,PHP語言究竟如何被執(zhí)行呢?

PHP語言到C語言之間的轉(zhuǎn)換如果使用“翻譯”這個(gè)詞是不夠準(zhǔn)確的,因?yàn)橐娌皇菍HP語言轉(zhuǎn)換成C語言,然后將轉(zhuǎn)換后的C語言編譯鏈接執(zhí)行。引擎在解析PHP代碼的時(shí)候通常是分為兩個(gè)部分,編譯和執(zhí)行:

編譯階段:引擎把PHP代碼轉(zhuǎn)換成opcode中間代碼執(zhí)行階段:引擎解釋并執(zhí)行編譯階段產(chǎn)生的opcode

關(guān)于op code會(huì)有專門的文章來介紹,現(xiàn)在網(wǎng)絡(luò)上也已經(jīng)有很多相關(guān)內(nèi)容的文章,總之PHP代碼會(huì)被編譯成_zend_op_array的形式,這是一個(gè)結(jié)構(gòu)體,其中包括很多相關(guān)屬性,以及最重要的成員zend_op *opcodes,即opcode的數(shù)組。執(zhí)行階段引擎會(huì)按照順序執(zhí)行各個(gè)opcode。

目前5.3.2版本的PHP中,opcode一共有154種,可以在{PHPSRC}/Zend/zend_vm_opcodes.h看到這些opcode的宏定義。op的結(jié)構(gòu)定義為:

struct _zend_op {opcode_handler_t handler;znode result;znode op1;znode op2;ulong extended_value;uint lineno;zend_uchar opcode;};

其中的成員opcode就對(duì)應(yīng)154個(gè)opcode宏定義中的一個(gè),每一個(gè)op根據(jù)opcode和操作數(shù)的類型不同都會(huì)對(duì)應(yīng)一個(gè)相關(guān)的執(zhí)行句柄(opcode_handler_t handler),執(zhí)行句柄是一個(gè)函數(shù)指針,op的執(zhí)行執(zhí)行句柄都定義在{PHPSRC}/Zend/zend_vm_execute.h中,這個(gè)文件可以通過一個(gè)PHP腳本({PHPSRC}/Zend/zend_vm_gen.php)來生成,這個(gè)PHP腳本用來生成zend_vm_opcodes.h和zend_vm_execute.h兩個(gè)文件,zend_vm_execute.h的內(nèi)容會(huì)根據(jù)生成時(shí)的參數(shù)不同而不同,這里主要是可以定置zend 引擎對(duì)op的分發(fā)方式,比如用CALL,SWITCH,GOTO,默認(rèn)的是用CALL,也就是函數(shù)調(diào)用,所以這里就以函數(shù)調(diào)用來簡(jiǎn)單的介紹下這個(gè)文件的功能(文件極大,有近36000行,所以不要仔細(xì)啃),在這個(gè)文件中所有定義為 static int ZEND_FASTCALL 并且以 ZEND_* 開頭的函數(shù)就是op的句柄,此文件中第一個(gè)函數(shù)execute是執(zhí)行op的主方法,以這里作為入口執(zhí)行一連串的op。可以說整個(gè)PHP的功能特性都是通過這些op句柄完成的(當(dāng)然這些句柄會(huì)間接調(diào)用其他模塊中的功能),那么這154個(gè)opcode如何對(duì)應(yīng)到這些static int ZEND_FASTCALL? ZEND_*的執(zhí)行句柄的呢?同樣在這個(gè)文件中,可以看到zend_init_opcodes_handlers函數(shù),這個(gè)函數(shù)初始化一個(gè) static const opcode_handler_t labels[]數(shù)組,這個(gè) labels數(shù)組就是handlers的一張表,這個(gè)表有近4000個(gè)項(xiàng),有一個(gè)算法將一個(gè)opcode映射到這個(gè)表中的一個(gè)元素,算法同樣在zend_vm_execute.h中可以找到,靠近文件結(jié)尾zend_vm_set_opcode_handler和zend_vm_get_opcode_handler就是這個(gè)算法的實(shí)現(xiàn)。

那么引擎是如何通過這些op handler實(shí)現(xiàn)PHP語言的特性的呢?這里我舉一個(gè)最簡(jiǎn)單的例子,考慮下面只有一行的PHP代碼:

<?php$a = 123;?>

通過某種方法(以后再介紹這些方法)我們可以知道這行代碼主要生成一個(gè)zend_op,其主要成員值為:

opcode = 38? (對(duì)應(yīng)#define ZEND_ASSIGN??38)op1?????? = $a ($a變量實(shí)際上是以cv形式存在,以后介紹)op2?????? = 123 (以const常量形式存在)

handler = ZEND_ASSIGN_SPEC_CV_CONST_HANDLER(得到這個(gè)handler的名字不是一件容易的事,以后給出方法)

opcode ZEND_ASSIGN的意思是將一個(gè)常量賦值給一個(gè)cv(compiled variable),這個(gè)cv其實(shí)就是$a變量的一種存在形式。在zend_vm_execute.h中搜索到ZEND_ASSIGN_SPEC_CV_CONST_HANDLER的定義,其主要功能就是取op2的值123,將其賦值給op1的變量,當(dāng)然這個(gè)過程比想象中的要復(fù)雜一些,會(huì)有變量的初始化,變量的寫時(shí)賦值等過程,以后會(huì)介紹每一個(gè)過程。這樣這條PHP語句的功能就完成了。可以看出,op handler只是按照一些固定的方式來對(duì)操作數(shù)op1 op2(可能還有result)進(jìn)行操作,handler不理會(huì)這些操作數(shù)中的具體值,這些值是在編譯階段生成op的時(shí)候確定的,比如如果$a = 123 改成 $a =456,那么生成的op中op2就是456了,handler始終按照固定的方式來處理。

因此我們能知道,PHP的執(zhí)行過程是先通過編譯器將PHP代碼編譯成op code,然后然后zend虛擬機(jī)按照一定順序執(zhí)行這些opcode,具體是將每個(gè)opcode分發(fā)給特定的op code handler。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 亚洲在线免费观看 | 国产精品搭讪系列在线观看 | 亚洲精品第一综合99久久 | 久国产精品视频 | 一级鲁丝片 | 麻豆视频传媒入口 | 日本三级网站 | 日韩在线看片 | 闫盼盼福利 | 色多多在深夜释放自己黄 | 成人你懂的 | 国产成人精品日本亚洲专 | 国产欧美视频在线观看 | 护士精品一区二区三区 | 国产精品久久久久久亚洲小说 | 欧美黄色一级在线 | 在线免费观看日韩视频 | 日韩欧美精品一区二区三区 | 成在线人永久免费播放视频 | 一级毛片免费在线播放 | 免费福利片 | 国产在线视频国产永久视频 | 欧美成人午夜视频免看 | 国产一级毛片亚洲久留木玲 | 亚洲欧美中文日韩在线v日本 | 成人国产在线视频在线观看 | 99热热热 | 国产一级毛片免 | 我要看欧美一级毛片 | 欧美成人高清手机在线视频 | 欧美另类一区 | 日韩综合久久 | 国产小视频免费 | 特级中国aaa毛片 | 粉嫩极品国产在线播放 | 国产综合精品久久久久成人影 | 欧美三j片| 激情亚洲婷婷 | 国产精品入口免费麻豆 | 一级做a爰片性色毛片刺激 一级做a爰片性色毛片视频图片 | 久久777国产线看观看精品卜 |