摘要:例如會被分解成解析語法分析這個過程是將詞法單元流數(shù)組轉(zhuǎn)換成一個由元素逐級嵌套所組成的代表了程序語法結(jié)構(gòu)的樹,這個樹就叫抽象語法樹。常用的有使用生成并使用抽象語法樹。
一般來說,程序中的一段源代碼在執(zhí)行之前會經(jīng)歷下面三個步驟
1 分詞/詞法分析
這個過程會將由字符組成的字符串分解成有意義的代碼快,這些代碼塊被稱為詞法單元。例如 var a = 4;會被分解成 var、a、=、4、;
2 解析/語法分析
這個過程是將詞法單元流(數(shù)組)轉(zhuǎn)換成一個由元素逐級嵌套所組成的代表了程序語法結(jié)構(gòu)的樹,這個樹就叫“抽象語法樹”(AST)。全稱 Abstract Syntax Tree。
3 代碼生成
將AST轉(zhuǎn)換成可執(zhí)行代碼的過程稱為代碼生成。拋開具體細節(jié)不講,簡單來說就是有某種方法可以將var a= 4; 的AST轉(zhuǎn)化為一組機器指令,用來創(chuàng)建一個叫做a的變量,并將一個值儲存在a中。
可能以上的這些聽起來有些云里霧里。因為在平時寫代碼的時候,不關(guān)注這些也能寫代碼。但是多了解一些,就多一扇看到未知世界的窗口。你肯定使用過前端的很多工具插件,webpack,eslint啥的。你知道這些工具的核心都是通過抽象語法樹這個概念來實現(xiàn)對代碼的檢查,分析,轉(zhuǎn)換的嗎?
抽象語法樹的定義In computer science, an abstract syntax tree (AST), or just syntax tree, is a tree representation of the abstract syntactic structure of source code written in a programming language.
翻譯一下就是:
在計算機科學中,一個抽象語法樹,或者詞法樹,是一個樹,這個樹表示或者說抽象出了編程語言的源代碼的結(jié)構(gòu)。
這個工具能在線可視化解析出一段代碼的抽象語法樹,可能能幫助你理解
這個可以進一步看更詳盡的信息
下面舉一個上邊工具中的demo,看看js在執(zhí)行之前的三步中的前兩步都是具體的干了啥。
var a = 42; var b = 5; function addA(d) { return a + d; } var c = addA(2) + b;
第一步,詞法分析,以上代碼詞法分析之后長成如下圖所示
第二步,語法分析,生產(chǎn)抽象語法樹,生成的抽象語法樹如下圖所示
JavaScript Parser 把js源碼轉(zhuǎn)化為抽象語法樹的解析器。前邊我們也說了。瀏覽器在執(zhí)行js之前會把js源碼通過解析器轉(zhuǎn)化為抽象語法樹,再進一步轉(zhuǎn)化為字節(jié)碼甚至是機器碼。
常用的JavaScript Parser有:
Esprima
UglifyJS2
Traceur
Acorn
Espree
Shfit
使用Esprima生成并使用抽象語法樹。通過esprima將一個空函數(shù)的源碼生成一棵AST樹
通過estraverse遍歷并更新AST樹
通過escodegen將AST重新生成源碼
抽象語法樹的用途其實從以上的三個工具,也可大致猜測到抽象語法樹的一般用途了。大致分為幾類吧
IDE插件,如代碼語法檢查,代碼風格檢查,代碼的格式化,代碼高亮,代碼錯誤等等之類的
代碼的混淆壓縮,如UglifyJS2等
轉(zhuǎn)換代碼的工具。如webpack,rollup,各種代碼規(guī)范之間的轉(zhuǎn)換,ts,jsx等轉(zhuǎn)換為原生js
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/94261.html
摘要:下面用具體代碼進行分析。匹配不到那么就是開始標簽,調(diào)用函數(shù)解析。如這里的轉(zhuǎn)化為加上是為了的下一步轉(zhuǎn)為函數(shù),本文中暫時不會用到。再把轉(zhuǎn)化后的內(nèi)容進。 什么是AST 在Vue的mount過程中,template會被編譯成AST語法樹,AST是指抽象語法樹(abstract syntax tree或者縮寫為AST),或者語法樹(syntax tree),是源代碼的抽象語法結(jié)構(gòu)的樹狀表現(xiàn)形式。...
摘要:首先一段代碼轉(zhuǎn)化成的抽象語法樹是一個對象,該對象會有一個頂級的屬性第二個屬性是是一個數(shù)組。最終完成整個文件依賴的處理。參考文章抽象語法樹一看就懂的抽象語法樹源碼所有的源碼已經(jīng)上傳 背景 隨著前端復雜度的不斷提升,誕生出很多打包工具,比如最先的grunt,gulp。到后來的webpack和 Parcel。但是目前很多腳手架工具,比如vue-cli已經(jīng)幫我們集成了一些構(gòu)建工具的使用。有的時...
摘要:無論你使用的是解釋型語言還是編譯型語言,都有一個共同的部分將源代碼作為純文本解析為抽象語法樹的數(shù)據(jù)結(jié)構(gòu)。和抽象語法樹相對的是具體語法樹,通常稱作分析樹。這是引入字節(jié)碼緩存的原因。 這是專門探索 JavaScript 及其所構(gòu)建的組件的系列文章的第 14 篇。 想閱讀更多優(yōu)質(zhì)文章請猛戳GitHub博客,一年百來篇優(yōu)質(zhì)文章等著你! 如果你錯過了前面的章節(jié),可以在這里找到它們: JavaS...
摘要:本文并不會告訴你抽象語法樹是什么,這需要你自己去了解,這里只是描述給帶來的一些變化。中在語法分析階段不再直接生成,而是先生成,所以過程多了一步詞法掃描分析,將源文件轉(zhuǎn)換成流語法分析,從流生成抽象語法樹從抽象語法樹生成。 本文大部分內(nèi)容參照 AST 的 RFC 文檔而成:https://wiki.php.net/rfc/abstract_syntax_tree,為了易于理解從源文檔中節(jié)選...
閱讀 1844·2021-09-14 18:03
閱讀 2276·2019-08-30 15:48
閱讀 1132·2019-08-30 14:09
閱讀 518·2019-08-30 12:55
閱讀 2739·2019-08-29 11:29
閱讀 1497·2019-08-26 13:43
閱讀 2320·2019-08-26 13:30
閱讀 2379·2019-08-26 12:17