go實(shí)現(xiàn)腳本解釋器gscript
前言
最近又在重新學(xué)習(xí)編譯原理了,其實(shí)兩年前也復(fù)習(xí)過,當(dāng)初是為了能實(shí)現(xiàn)通過 MySQL
的 DDL
生成 Python
中 sqlalchemy
的 model
。
相關(guān)文章在這里:手寫一個(gè)詞法分析器
雖然完成了相關(guān)功能,但現(xiàn)在看來其實(shí)實(shí)現(xiàn)的比較糙的,而且也只運(yùn)用到了詞法分析;所以這次我的目的是可以通過詞法分析->語法分析->語義分析 最終能實(shí)現(xiàn)一個(gè)功能完善的腳本”語言”。
效果
現(xiàn)在也有了一些階段性的成果,如下圖所示:
目前具備以下基本功能:
- 變量聲明與賦值(只支持 int)
- 二次運(yùn)算(優(yōu)先級(jí)支持)
- 語法檢查
- debug 模式,可以打印 AST
感興趣的朋友可以在這里查看源碼:https://github.com/crossoverJie/gscript
本地有 go 環(huán)境的話也可以安裝運(yùn)行。
go get github.com/crossoverJie/gscript
gscript -h
或者直接下載二進(jìn)制文件運(yùn)行:
https://github.com/crossoverJie/gscript/releases
實(shí)現(xiàn)
當(dāng)前版本是使用 go 編寫的,確實(shí)也如標(biāo)題所說,核心代碼還不到 1k 行代碼,當(dāng)然這也和目前功能簡(jiǎn)陋有關(guān)。
不過麻雀雖小五臟俱全,從當(dāng)前版本還是運(yùn)用到了編譯原理中的部分知識(shí):詞法、語法分析。
基本實(shí)現(xiàn)流程如上圖:
通過詞法分析器將源碼中解析出 token
再通過對(duì) token 推導(dǎo)生成出抽象語法樹(AST)
如果語法語法出現(xiàn)錯(cuò)誤,這一步驟便會(huì)拋出編譯失敗,比如 2*(1+
少了一個(gè)括號(hào)。
因?yàn)闆]有使用類似于 ANTLR
這樣工具來輔助生成代碼(不然功能也不會(huì)只有這么點(diǎn)),所以其中的詞法、語法分析都是手寫的,代碼量并不大,對(duì)于想要調(diào)試的朋友可以直接查看源碼。
詞法分析器:token/token.go:39
語法分析器:syntax/syntax.go
其中會(huì)涉及到一些概念,比如有限狀態(tài)機(jī)、遞歸下降算法等知識(shí)點(diǎn)就沒在本文討論了,后續(xù)這個(gè)項(xiàng)目功能更加完善后也會(huì)重頭整理。
規(guī)劃
最后是畫餅階段了,不出意外后續(xù)會(huì)繼續(xù)新增如下功能:
- 更多的基礎(chǔ)類型,string/long 之類的。
- 變量作用域、函數(shù)。
- 甚至是閉包。
- OOP 肯定也少不了。
這些特性都實(shí)現(xiàn)后那也算是一個(gè)”現(xiàn)代”的腳本語言了,后續(xù)我也會(huì)繼續(xù)更新學(xué)習(xí)和實(shí)現(xiàn)過程中的有趣內(nèi)容。
源碼地址:https://github.com/crossoverJie/gscript
以上就是go實(shí)現(xiàn)腳本解釋器gscript的詳細(xì)內(nèi)容,更多關(guān)于go gscript腳本解釋器的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
golang替換無法顯示的特殊字符(\u0000,?\000,?^@)
這篇文章主要介紹了golang替換無法顯示的特殊字符,包括的字符有\(zhòng)u0000,?\000,?^@等,下文詳細(xì)資料,需要的小伙伴可以參考一下2022-04-04淺談Go語言不提供隱式數(shù)字轉(zhuǎn)換的原因
本文主要介紹了淺談Go語言不提供隱式數(shù)字轉(zhuǎn)換的原因,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03Golang使用Channel組建高并發(fā)HTTP服務(wù)器
Golang 作為一門高效的語言,在網(wǎng)絡(luò)編程方面表現(xiàn)也非常出色,這篇文章主要介紹了如何使用 Golang 和 Channel 組建高并發(fā) HTTP 服務(wù)器,感興趣的可以了解一下2023-06-06pytorch中的transforms.ToTensor和transforms.Normalize的實(shí)現(xiàn)
本文主要介紹了pytorch中的transforms.ToTensor和transforms.Normalize的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04簡(jiǎn)單易用的Go逗號(hào)comma ok模式使用詳解
這篇文章主要為大家介紹了簡(jiǎn)單易用的Go逗號(hào)comma ok模式使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11golang使用信號(hào)量熱更新的實(shí)現(xiàn)示例
這篇文章主要介紹了golang使用信號(hào)量熱更新的實(shí)現(xiàn)示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04Go語言rune與字符串轉(zhuǎn)換的密切關(guān)系解析
這篇文章主要為大家介紹了Go語言rune與字符串轉(zhuǎn)換的密切關(guān)系示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12