成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

幾百行代碼實現(xiàn)一個腳本解釋器

開發(fā) 前端
當(dāng)前版本是使用 go 編寫的,確實也如標(biāo)題所說,核心代碼還不到 1k 行代碼,當(dāng)然這也和目前功能簡陋有關(guān)。

前言

最近又在重新學(xué)習(xí)編譯原理了,其實兩年前也復(fù)習(xí)過,當(dāng)初是為了能實現(xiàn)通過 MySQL 的 DDL 生成 Python 中 sqlalchemy 的 model

幾百行代碼實現(xiàn)一個腳本解釋器

雖然完成了相關(guān)功能,但現(xiàn)在看來其實實現(xiàn)的比較糙的,而且也只運用到了詞法分析;所以這次我的目的是可以通過詞法分析->語法分析->語義分析 最終能實現(xiàn)一個功能完善的腳本"語言"。

效果

現(xiàn)在也有了一些階段性的成果,如下圖所示:

幾百行代碼實現(xiàn)一個腳本解釋器

幾百行代碼實現(xiàn)一個腳本解釋器

目前具備以下基本功能:

  • 變量聲明與賦值(只支持 int)。
  • 二次運算(優(yōu)先級支持)。
  • 語法檢查。
  • debug 模式,可以打印 AST。

感興趣的朋友可以在這里查看源碼: https://github.com/crossoverJie/gscript。

本地有 go 環(huán)境的話也可以安裝運行。

go get github.com/crossoverJie/gscript
gscript -h

或者直接下載二進(jìn)制文件運行:https://github.com/crossoverJie/gscript/releases。

實現(xiàn)

當(dāng)前版本是使用 go 編寫的,確實也如標(biāo)題所說,核心代碼還不到 1k 行代碼,當(dāng)然這也和目前功能簡陋有關(guān)。

不過麻雀雖小五臟俱全,從當(dāng)前版本還是運用到了編譯原理中的部分知識:詞法、語法分析。

幾百行代碼實現(xiàn)一個腳本解釋器

基本實現(xiàn)流程如上圖:

  • 通過詞法分析器將源碼中解析出 token。
  • 再通過對 token 推導(dǎo)生成出抽象語法樹(AST) 如果語法語法出現(xiàn)錯誤,這一步驟便會拋出編譯失敗,比如 2*(1+少了一個括號。

因為沒有使用類似于 ANTLR 這樣工具來輔助生成代碼(不然功能也不會只有這么點),所以其中的詞法、語法分析都是手寫的,代碼量并不大,對于想要調(diào)試的朋友可以直接查看源碼。

詞法分析器:token/token.go:39 語法分析器:syntax/syntax.go。

其中會涉及到一些概念,比如有限狀態(tài)機、遞歸下降算法等知識點就沒在本文討論了,后續(xù)這個項目功能更加完善后也會重頭整理。

規(guī)劃

最后是畫餅階段了,不出意外后續(xù)會繼續(xù)新增如下功能:

  • 更多的基礎(chǔ)類型,string/long 之類的。
  • 變量作用域、函數(shù)。
  • 甚至是閉包。
  • OOP 肯定也少不了。

這些特性都實現(xiàn)后那也算是一個"現(xiàn)代"的腳本語言了,后續(xù)我也會繼續(xù)更新學(xué)習(xí)和實現(xiàn)過程中的有趣內(nèi)容。

源碼地址: https://github.com/crossoverJie/gscript。

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2022-06-28 08:17:10

JSON性能反射

2024-05-15 10:07:11

Agents人工智能CSV

2013-03-04 10:22:30

Python

2017-03-28 21:03:35

代碼React.js

2022-01-26 16:30:47

代碼虛擬機Linux

2014-05-15 09:45:58

Python解析器

2023-12-25 15:28:57

Python工具pywebio

2014-01-09 09:42:56

Python語言檢測器

2022-08-10 19:28:40

Hadoop數(shù)據(jù)庫

2022-01-05 08:58:08

Python解釋器編程語言

2021-08-16 10:40:36

數(shù)據(jù)庫耦合

2020-06-11 08:48:49

JavaScript開發(fā)技術(shù)

2020-10-20 07:49:12

百度搜索引擎

2012-08-14 10:44:52

解釋器編程

2024-01-31 08:16:38

IPythonPython解釋器

2022-11-03 08:13:52

echo 命令Linux

2020-09-21 14:37:09

Python代碼微信

2011-08-23 17:42:42

Lua腳本

2018-08-26 05:38:44

路由器調(diào)制解調(diào)器網(wǎng)絡(luò)設(shè)備

2014-07-08 09:27:24

SQLSERVER腳本
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 欧美日韩亚洲一区 | 亚洲精品日韩一区二区电影 | 这里精品 | 欧美日韩国产一区 | 一区二区三区影院 | 一区二区三区在线播放视频 | 日韩久久久久久 | 国产一级视频 | 国产日韩精品一区二区三区 | 国产精品日韩 | 国产一区中文字幕 | 九九伊人sl水蜜桃色推荐 | 99热在线免费 | 国产成人精品午夜视频免费 | 亚洲欧美日韩在线一区二区 | 99热国产精品 | 精品欧美乱码久久久久久1区2区 | 国产一区| 成人性视频免费网站 | 91精品国产综合久久婷婷香蕉 | 国产美女黄色片 | 久久久久av | 亚洲免费在线视频 | 激情欧美日韩一区二区 | 91日日| 国产成人网 | 欧美激情在线精品一区二区三区 | 国产福利在线免费观看 | 精品久久国产 | 羞羞的视频网站 | 欧美韩一区二区三区 | 国产原创视频 | 久久久久亚洲精品 | 亚洲一区二区久久 | 成人福利网 | 久久精品久久久久久 | 91文字幕巨乱亚洲香蕉 | 国产精品久久久久久久久免费桃花 | 欧美性猛交一区二区三区精品 | 成人精品一区二区三区 | 国产精品视频久久久久久 |