作者:aaaron7
链接:
https://www.zhihu.com/question/36756224/answer/88530013
如果是用 Haskell 的话,三篇文章足矣。
prerequisite: 懂 state monad就行了
第一篇,《How to build a monadic interpreter in one day》http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.368.2522
跟着做,可以完成一个简单的backend, 也就是架构基本的AST 并执行的步骤。
然后到frontend, 也就是parser的部分你就会发现你看不懂了, 这个时候看第二篇。(因为该文的 parser 部分其实是 第二篇 的一个浓缩版,所以不看第二篇基本很难看懂这个部分)
第二篇