溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python編譯過程和執(zhí)行原理是什么

發(fā)布時間:2020-09-23 11:10:38 來源:億速云 閱讀:518 作者:Leah 欄目:編程語言

這期內(nèi)容當中小編將會給大家?guī)碛嘘P(guān)python編譯過程和執(zhí)行原理是什么,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

python編譯過程和執(zhí)行原理

(1)python執(zhí)行原理

 這里的解釋執(zhí)行是相對于編譯執(zhí)行而言的。我們都知道,使用C/C++之類的編譯性語言編寫的程序,是需要從源文件轉(zhuǎn)換成計算機使用的機器語言,經(jīng)過鏈接器鏈接之后形成了二進制的可執(zhí)行文件。運行該程序的時候,就可以把二進制程序從硬盤載入到內(nèi)存中并運行。

但是對于Python而言,python源碼不需要編譯成二進制代碼,它可以直接從源代碼運行程序。當我們運行python文件程序的時候,python解釋器將源代碼轉(zhuǎn)換為字節(jié)碼,然后再由python解釋器來執(zhí)行這些字節(jié)碼。這樣,python就不用擔心程序的編譯,庫的鏈接加載等問題了。

對于python解釋語言,有以下3方面的特性:

每次運行都要進行轉(zhuǎn)換成字節(jié)碼,然后再有虛擬機把字節(jié)碼轉(zhuǎn)換成機器語言,最后才能在硬件上運行。與編譯性語言相比,每次多出了編譯和鏈接的過程,性能肯定會受到影響。

由于不用關(guān)心程序的編譯和庫的鏈接等問題,開發(fā)的工作也就更加輕松啦。

python代碼與機器底層更遠了,python程序更加易于移植,基本上無需改動就能在多平臺上運行。

在具體計算機上實現(xiàn)一種語言,首先要確定的是表示該語言語義解釋的虛擬計算機,一個關(guān)鍵的問題是程序執(zhí)行時的基本表示是實際計算機上的機器語言還是虛擬機的機器語言。這個問題決定了語言的實現(xiàn)。根據(jù)這個問題的回答,可以將程序設(shè)計語言劃分為兩大類:編譯型語言和解釋型語言。

編譯實現(xiàn)的語言,如:C、C++、Fortran、Pascal、Ada。由編譯型語言編寫的源程序需要經(jīng)過編譯,匯編和鏈接才能輸出目標代碼,然后由機器執(zhí)行目標代碼。目標代碼是有機器指令組成,不能獨立運行,因為源程序中可能使用了一些匯編程序不能解釋引用的庫函數(shù),而庫函數(shù)又不在源程序中,此時還需要鏈接程序完成外部引用和目標模板調(diào)用的鏈接任務(wù),最后才能輸出可執(zhí)行代碼。

 解釋型語言,解釋器不產(chǎn)生目標機器代碼,而是產(chǎn)生中間代碼,這種中間代碼與機器代碼不同,中間代碼的解釋是由軟件支持的,不能直接使用在硬件上。該軟件解釋器通常會導(dǎo)致執(zhí)行效率較低,用解釋型語言編寫的程序是由另一個可以理解中間代碼的解釋程序執(zhí)行的。和編譯的程序不同的是, 解釋程序的任務(wù)是逐一將源代碼的語句解釋成可執(zhí)行的機器指令,不需要將源程序翻譯成目標代碼再執(zhí)行。對于解釋型語言,需要一個專門的解釋器來執(zhí)行該程序,每條語句只有在執(zhí)行是才能被翻譯,這種解釋型語言每執(zhí)行一次就翻譯一次,因而效率低下。

Java解釋器,java很特殊,java是需要編譯的,但是沒有直接編譯成機器語言,而是編譯成字節(jié)碼,然后在Java虛擬機上用解釋的方式執(zhí)行字節(jié)碼。Python也使用了類似的方式,先將python編譯成python字節(jié)碼,然后由一個專門的python字節(jié)碼解釋器負責解釋執(zhí)行字節(jié)碼。

 python是一門解釋語言,但是出于效率的考慮,提供了一種編譯的方法。編譯之后就得到pyc文件,存儲了字節(jié)碼。python這點和java很類似,但是java與python不同的是,python是一個解釋型的語言,所以編譯字節(jié)碼不是一個強制的操作,事實上,編譯是一個自動的過程,一般不會在意它的存在。編譯成字節(jié)碼可以節(jié)省加載模塊的時間,提高效率。

  除了效率之外,字節(jié)碼的形式也增加了反向工程的難度,可以保護源代碼。這個只是一定程度上的保護,反編譯還是可以的。

(2)Python內(nèi)部執(zhí)行過程

一、編譯過程概述

當我們執(zhí)行Python代碼的時候,在Python解釋器用四個過程“拆解”我們的代碼,最終被CPU執(zhí)行返回給用戶。

首先當用戶鍵入代碼交給Python處理的時候會先進行詞法分析,例如用戶鍵入關(guān)鍵字或者當輸入關(guān)鍵字有誤時,都會被詞法分析所觸發(fā),不正確的代碼將不會被執(zhí)行。

下一步Python會進行語法分析,例如當"for i in test:"中,test后面的冒號如果被寫為其他符號,代碼依舊不會被執(zhí)行。

下面進入最關(guān)鍵的過程,在執(zhí)行Python前,Python會生成.pyc文件,這個文件就是字節(jié)碼,如果我們不小心修改了字節(jié)碼,Python下次重新編譯該程序時會和其上次生成的字節(jié)碼文件進行比較,如果不匹配則會將被修改過的字節(jié)碼文件進行覆蓋,以確保每次編譯后字節(jié)碼的準確性。

那么什么是字節(jié)碼?字節(jié)碼在Python虛擬機程序里對應(yīng)的是PyCodeObject對象。.pyc文件是字節(jié)碼在磁盤上的表現(xiàn)形式。簡單來說就是在編譯代碼的過程中,首先會將代碼中的函數(shù)、類等對象分類處理,然后生成字節(jié)碼文件。有了字節(jié)碼文件,CPU可以直接識別字節(jié)碼文件進行處理,接著Python就可執(zhí)行了。

上述就是小編為大家分享的python編譯過程和執(zhí)行原理是什么了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI