自定義語言的實現——直譯器模式(二)
18.2 文法規則和抽象語法樹
直譯器模式描述瞭如何為簡單的語言定義一個文法,如何在該語言中表示一個句子,以及如何解釋這些句子。在正式分析直譯器模式結構之前,我們先來學習如何表示一個語言的文法規則以及如何構造一棵抽象語法樹。
在前面所提到的加法/減法直譯器中,每一個輸入表示式,例如“1 + 2 + 3 – 4 + 1”,都包含了三個語言單位,可以使用如下文法規則來定義:
expression ::= value | operation operation ::= expression '+' expression | expression '-' expression value ::= an integer //一個整數值 |
該文法規則包含三條語句,第一條表示表示式的組成方式,其中value和operation是後面兩個語言單位的定義,每一條語句所定義的字串如operation和value稱為語言構造成分或語言單位,符號“::=”表示“定義為”的意思,其左邊的語言單位通過右邊來進行說明和定義,語言單位對應終結符表示式和非終結符表示式。如本規則中的operation是非終結符表示式,它的組成元素仍然可以是表示式,可以進一步分解,而value是終結符表示式,它的組成元素是最基本的語言單位,不能再進行分解。
在文法規則定義中可以使用一些符號來表示不同的含義,如使用“|”表示或,使用“{”和“}”表示組合,使用“*”表示出現0次或多次等,其中使用頻率最高的符號是表示“或”關係的“|”,如文法規則“boolValue ::= 0 | 1”表示終結符表示式boolValue的取值可以為0或者1。
除了使用文法規則來定義一個語言,在直譯器模式中還可以通過一種稱之為抽象語法樹(Abstract Syntax Tree, AST)的圖形方式來直觀地表示語言的構成,每一棵抽象語法樹對應一個語言例項,如加法/減法表示式語言中的語句“1+ 2 + 3 – 4 + 1”,可以通過如圖18-2所示抽象語法樹來表示:
圖18-2 抽象語法樹示意圖
在該抽象語法樹中,可以通過終結符表示式value和非終結符表示式operation組成複雜的語句,每個文法規則的語言例項都可以表示為一個抽象語法樹,即每一條具體的語句都可以用類似圖18-2所示的抽象語法樹來表示,在圖中終結符表示式類的例項作為樹的葉子節點,而非終結符表示式類的例項作為非葉子節點,它們可以將終結符表示式類的例項以及包含終結符和非終結符例項的子表示式作為其子節點。抽象語法樹描述瞭如何構成一個複雜的句子,通過對抽象語法樹的分析,可以識別出語言中的終結符類和非終結符類。
【作者:劉偉 http://blog.csdn.net/lovelion】
相關文章
- 自定義語言的實現——直譯器模式(五)模式
- 自定義語言的實現——直譯器模式(四)模式
- 自定義語言的實現——直譯器模式(三)模式
- Java設計模式-17、直譯器模式-自定義語言的實現Java設計模式
- 實現JavaScript語言直譯器(三)JavaScript
- 源語言、目標語言、翻譯器、編譯器、直譯器編譯
- 直譯器模式模式
- 使用PHP實現詞法分析與自定義語言PHP詞法分析
- 終:直譯器模式模式
- Go 語言實現解析器翻譯Go
- 程式語言實現模式模式
- 中文程式語言中文程式語言實現:翻譯器
- 24_直譯器模式模式
- Python直譯器簡介(4):動態語言Python
- 設計模式之直譯器模式設計模式
- 設計模式(十五):直譯器模式設計模式
- Rust語言之GoF設計模式: 直譯器Interpreter模式RustGo設計模式
- 魔獸爭霸自定義地圖直譯器存在安全漏洞地圖
- 設計模式學習筆記(二十二)直譯器模式及其實現設計模式筆記
- 從編譯原理看一個直譯器的實現編譯原理
- Django高階程式設計之自定義Field實現多語言Django程式設計
- 深入 WebAssembly 之直譯器實現篇Web
- 直譯器模式(Interpreter)模式
- 設計模式(十五)直譯器設計模式
- 簡說設計模式——直譯器模式設計模式
- 極簡設計模式-直譯器模式設計模式
- Python設計模式-直譯器模式Python設計模式
- JAVA設計模式之直譯器模式Java設計模式
- 淺談如何實現自定義的 iterator 之二
- SAPGUI裡實現自定義的語法檢查GUI
- 設計模式--直譯器模式和狀態模式設計模式
- 什麼是程式語言,什麼是Python直譯器Python
- 化繁為簡的翻譯機——直譯器模式模式
- 用 Python 實現 Python 直譯器Python
- Golang實現微型數學運算直譯器Golang
- 直譯器構造實現函式呼叫函式
- 23種設計模式之直譯器模式設計模式
- 實現指令碼直譯器 - 詞法分析器指令碼詞法分析