簡單實(shí)例帶你了解Python的編譯和執(zhí)行全過程
基本說明
python 是一種解釋型的編程語言,所以不像編譯型語言那樣需要顯式的編譯過程。然而,在 Python 代碼執(zhí)行之前,它需要被解釋器轉(zhuǎn)換成字節(jié)碼,這個(gè)過程就是 Python 的編譯過程。
DEMO演示講解
假設(shè)我們有以下 Python 代碼:
def add_numbers(a, b): return a + b print(add_numbers(2, 3))
以下是 Python 編譯與執(zhí)行的具體步驟:
詞法分析(Lexical Analysis):
解釋器會(huì)先將 Python 源代碼分解成一系列的 Token(標(biāo)記),每個(gè) Token 包含了源代碼中的一個(gè)詞匯單元(例如變量名、關(guān)鍵字、操作符等)。這個(gè)過程又叫做掃描(Scanning),Python 解釋器使用了一個(gè)名為 tokenizer
的模塊來完成這個(gè)任務(wù)。Python 解釋器將上面的代碼分解成以下 Token:
def, add_numbers, (, a, ,, b, ), :, return, a, +, b, print, (, add_numbers, (, 2, ,, 3, ), ), EOF
語法分析(Parsing):
解釋器會(huì)使用 Token,構(gòu)建語法樹(Syntax Tree)或抽象語法樹(Abstract Syntax Tree,AST
),以此來表示代碼的結(jié)構(gòu)和語法。AST
包含了源代碼中的所有關(guān)鍵信息,并為解釋器提供了執(zhí)行代碼的指令。Python 解釋器使用了一個(gè)名為 parser
的模塊來完成這個(gè)任務(wù)。Python 解釋器使用 上面詞法分析的Token 生成以下 AST
:
Module(body=[ FunctionDef(name='add_numbers', args=arguments(args=[ arg(arg='a', annotation=None), arg(arg='b', annotation=None) ], vararg=None, kwonlyargs=[], kw_defaults=[], kwarg=None, defaults=[]), body=[Return(value=BinOp(left=Name(id='a', ctx=Load()), op=Add(), right=Name(id='b', ctx=Load())))], decorator_list=[], returns=None ), Expr(value=Call(func=Name(id='print', ctx=Load()), args=[Call(func=Name(id='add_numbers', ctx=Load()), args=[Num(n=2), Num(n=3)], keywords=[])], keywords=[])) ])
編譯(Compilation):
在生成AST
之后,解釋器將使用它來生成字節(jié)碼(Bytecode
)。字節(jié)碼是一種類似于匯編語言的中間代碼,是 Python 解釋器的一種低級(jí)表示方式。Python 解釋器使用了一個(gè)名為 compiler
的模塊來完成這個(gè)任務(wù)。Python 解釋器使用 上面得到的AST
生成以下字節(jié)碼:
1 0 LOAD_CONST 0 (<code object add_numbers at 0x10d0db7c0, file "<stdin>", line 1>) 2 LOAD_CONST 1 ('add_numbers') 4 MAKE_FUNCTION 0 6 STORE_NAME 0 (add_numbers) 3 8 LOAD_NAME 1 (add_numbers) 10 LOAD_CONST 2 (2) 12 LOAD_CONST 3 (3) 14 CALL_FUNCTION 2 16 CALL_FUNCTION 1 18 POP_TOP 20 LOAD_CONST 4 (None) 22 RETURN_VALUE
執(zhí)行(Execution):
最后,Python 解釋器將執(zhí)行字節(jié)碼,并將其轉(zhuǎn)換成機(jī)器碼來完成具體的操作。執(zhí)行過程是由解釋器來完成的,解釋器會(huì)根據(jù)字節(jié)碼中存儲(chǔ)的指令,按照一定的順序來執(zhí)行代碼。Python 解釋器按照上面的指令逐個(gè)執(zhí)行字節(jié)碼,最終輸出 5
。
其他說明
Python 是一種動(dòng)態(tài)語言,它的特點(diǎn)是代碼的執(zhí)行過程中能夠進(jìn)行大量的動(dòng)態(tài)操作。在 Python 編譯過程中,生成字節(jié)碼的過程和執(zhí)行字節(jié)碼的過程是同時(shí)進(jìn)行的,這意味著 Python 解釋器在執(zhí)行代碼時(shí)可以根據(jù)實(shí)際情況來進(jìn)行優(yōu)化,提高程序的性能。
例如,在運(yùn)行時(shí),Python 解釋器會(huì)使用一些高級(jí)的優(yōu)化技術(shù),例如 JIT(Just-In-Time)編譯、動(dòng)態(tài)類型推斷等,來提高代碼的執(zhí)行效率。這些優(yōu)化技術(shù)在編譯期間是不可用的,因?yàn)?Python 中很多類型和屬性是在運(yùn)行時(shí)才能確定的。
此外,Python 還支持元編程和動(dòng)態(tài)導(dǎo)入等高級(jí)特性。元編程是指在運(yùn)行時(shí)生成和操作程序的代碼,這種方式可以使程序更加靈活和可擴(kuò)展。動(dòng)態(tài)導(dǎo)入是指在運(yùn)行時(shí)根據(jù)需要?jiǎng)討B(tài)加載和執(zhí)行代碼,這種方式可以使程序更加動(dòng)態(tài)和可配置。這些特性在編譯和執(zhí)行過程中會(huì)對(duì) Python 解釋器的行為產(chǎn)生影響,需要在編譯器和解釋器中進(jìn)行特殊處理。
總之,Python 的動(dòng)態(tài)特性使得編譯和執(zhí)行過程相互交織,使得編譯器和解釋器需要更加靈活和智能地處理代碼。
到此這篇關(guān)于簡單實(shí)例帶你了解Python的編譯和執(zhí)行全過程的文章就介紹到這了,更多相關(guān)Python的編譯和執(zhí)行全過程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在Python的Django框架中編寫錯(cuò)誤提示頁面
這篇文章主要介紹了在Python的Django框架中編寫錯(cuò)誤提示頁面,包括傳統(tǒng)的404頁面和設(shè)置連接中斷警告等,需要的朋友可以參考下2015-07-07在Python中使用itertools模塊中的組合函數(shù)的教程
這篇文章主要介紹了在Python中使用itertools模塊中的組合函數(shù)的教程,來自IBM官方技術(shù)文檔,需要的朋友可以參考下2015-04-04Python中表達(dá)式x += y和x = x+y 的區(qū)別詳解
這篇文章主要跟大家介紹了關(guān)于Python中x += y和x = x+y 的區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-06-06Django處理文件上傳File Uploads的實(shí)例
今天小編就為大家分享一篇Django處理文件上傳File Uploads的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05解決Pycharm在Debug的時(shí)候一直“Connected”沒有下一步動(dòng)作問題
這篇文章主要介紹了解決Pycharm在Debug的時(shí)候一直“Connected”沒有下一步動(dòng)作問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08分享5個(gè)數(shù)據(jù)處理更加靈活的pandas調(diào)用函數(shù)方法
這篇文章主要介紹了分享5個(gè)數(shù)據(jù)處理更加靈活的pandas調(diào)用函數(shù)方法,文章基于python的相關(guān)內(nèi)容展開詳細(xì)介紹,需要的小伙伴可以參考一下2022-04-04Python Pytorch深度學(xué)習(xí)之Tensors張量
今天小編就為大家分享一篇Pytorch之Tensors張量的文章,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-10-10