淺析AST抽象語(yǔ)法樹及Python代碼實(shí)現(xiàn)
在計(jì)算機(jī)科學(xué)中,抽象語(yǔ)法樹(abstract syntax tree或者縮寫為AST),或者語(yǔ)法樹(syntax tree),是源代碼的抽象語(yǔ)法結(jié)構(gòu)的樹狀表現(xiàn)形式,這里特指編程語(yǔ)言的源代碼。樹上的每個(gè)節(jié)點(diǎn)都表示源代碼中的一種結(jié)構(gòu)。之所以說(shuō)語(yǔ)法是“抽象”的,是因?yàn)檫@里的語(yǔ)法并不會(huì)表示出真實(shí)語(yǔ)法中出現(xiàn)的每個(gè)細(xì)節(jié)。比如,嵌套括號(hào)被隱含在樹的結(jié)構(gòu)中,并沒有以節(jié)點(diǎn)的形式呈現(xiàn);而類似于if-condition-then這樣的條件跳轉(zhuǎn)語(yǔ)句,可以使用帶有兩個(gè)分支的節(jié)點(diǎn)來(lái)表示。
和抽象語(yǔ)法樹相對(duì)的是具體語(yǔ)法樹(concrete syntaxtree),通常稱作分析樹(parse tree)。一般的,在源代碼的翻譯和編譯過(guò)程中,語(yǔ)法分析器創(chuàng)建出分析樹。一旦AST被創(chuàng)建出來(lái),在后續(xù)的處理過(guò)程中,比如語(yǔ)義分析階段,會(huì)添加一些信息。
抽象語(yǔ)法樹的結(jié)構(gòu)不依賴于源語(yǔ)言的文法,也就是語(yǔ)法分析階段所采用的上下文無(wú)關(guān)文法。因?yàn)樵赑arser工程中,經(jīng)常會(huì)對(duì)文法進(jìn)行等價(jià)的轉(zhuǎn)換(消除左遞歸、回溯、二義性等),這樣會(huì)給文法引入一些多余的成分,對(duì)后續(xù)階段造成不利影響,甚至?xí)垢麟A段變得混亂。因此,很多編譯器(包括GJC)經(jīng)常要獨(dú)立地構(gòu)造語(yǔ)法分析樹,為前、后端建立一個(gè)清晰的接口。
Python實(shí)現(xiàn)
假設(shè)對(duì)'a + 3 * b'進(jìn)行解釋,其中a=2,b=5
代碼很簡(jiǎn)單,就不再進(jìn)行詳細(xì)的解釋了。
Num = lambda env, n: n
Var = lambda env, x: env[x]
Add = lambda env, a, b:_eval(env, a) + _eval(env, b)
Mul = lambda env, a, b:_eval(env, a) * _eval(env, b)
_eval = lambda env, expr:expr[0](env, *expr[1:])
env = {'a':2, 'b':5}
tree = (Add, (Var, 'a'),
(Mul, (Num, 3),
(Var, 'b')))
print _eval(env, tree)
輸出結(jié)果為17
- 在樹莓派2或樹莓派B+上安裝Python和OpenCV的教程
- python 生成目錄樹及顯示文件大小的代碼
- 決策樹的python實(shí)現(xiàn)方法
- Python Trie樹實(shí)現(xiàn)字典排序
- python數(shù)據(jù)結(jié)構(gòu)之二叉樹的建立實(shí)例
- python二叉樹遍歷的實(shí)現(xiàn)方法
- python數(shù)據(jù)結(jié)構(gòu)樹和二叉樹簡(jiǎn)介
- python數(shù)據(jù)結(jié)構(gòu)之二叉樹的遍歷實(shí)例
- 樹莓派中python獲取GY-85九軸模塊信息示例
- python二叉樹的實(shí)現(xiàn)實(shí)例
- python實(shí)現(xiàn)繪制樹枝簡(jiǎn)單示例
- Python中的二叉樹查找算法模塊使用指南
- python實(shí)現(xiàn)目錄樹生成示例
相關(guān)文章
基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能
這篇文章主要介紹了基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08
Flask框架使用DBUtils模塊連接數(shù)據(jù)庫(kù)操作示例
這篇文章主要介紹了Flask框架使用DBUtils模塊連接數(shù)據(jù)庫(kù)操作,結(jié)合實(shí)例形式較為詳細(xì)的分析了flask框架使用DBUtils模塊連接數(shù)據(jù)庫(kù)的常見操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-07-07
Python實(shí)戰(zhàn)之設(shè)計(jì)一個(gè)多功能辦公小工具
這篇文章主要介紹了通過(guò)Python制作一個(gè)多功能的辦公小工具,可以實(shí)現(xiàn)應(yīng)用、網(wǎng)頁(yè)直達(dá)以及天氣查詢,代碼具有一定學(xué)習(xí)價(jià)值,需要的小伙伴可以了解一下2021-12-12
Python環(huán)境的安裝以及PyCharm編輯器配置教程詳解
優(yōu)質(zhì)的教程可以讓我們少走很多彎路,這一點(diǎn)毋庸置疑。這篇文章主要為大家介紹了純凈Python環(huán)境的安裝以及PyCharm編輯器的配置,需要的可以參考一下2023-04-04
Python利用自帶模塊實(shí)現(xiàn)屏幕像素高效操作
這篇文章主要為大家詳細(xì)介紹了Python如何利用自帶模塊實(shí)現(xiàn)屏幕像素高效操作,文中的示例代碼講解詳,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-02-02
python opencv 圖像處理之圖像算數(shù)運(yùn)算及修改顏色空間
這篇文章主要介紹了python opencv 圖像處理之圖像算數(shù)運(yùn)算及修改顏色空間,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-08-08

