编程语言的自举

发布于 2024-06-07 11:59:43 字数 1430 浏览 16 评论 0

一. 自举过程

自举(bootstrapping)字面理解就是自己能把自己给举起来,换做编程语言来讲就是,自己编译自己,可以看看(Wiki 上面的解释)( https://en.wikipedia.org/wiki/Bootstrapping_(compilers))

那么语言自举过程到底是个怎么样的过程?

下面选取了来自知乎 vczh 轮子哥的解释:

  • 用 C++把那个编译器(A)写出来,顺便留下很多测试用例。
  • 用 V 语言把那个编译器写(B)出来,用 A.exe 来编译 B,修改直到所有测试用例都通过为止。
  • B.exe 来编译 B 自己得到 B2.exe,修改直到 B2.exe 所有测试用例都通过为止。这是为了保证,就算 B 本身有很多 bug,至少编译自己是没有 bug 的,从而你就可以走到第四步。
  • 当你觉得有信心了,用 A.exe 把 B 编译一遍,就得到了 B.exe。然后 A 的代码和 A.exe 都在也不需要存在了,删掉他们。以后你就不断的用 B.exe 来编译下一个版本的 B 就好了。就自举了。

自举的过程大概是这样,都需要一个最初的编译器,而最初的编译器是不会关心最优,只在乎写的是否正确,这样造成的效率也是十分低下的。

二. 自举的语言

现在自举的语言有很多比如:

三. 自举的好处

  • 语言通过自我编译,自我迭代,达到本身语言的真正成熟稳定
  • 对编译器后端的优化不仅会优化以后所有编译出来的其它程序的效率,也会优化编译器本身的效率
  • 使开发编译器的环境和使用这门语言开发的其它程序一致
  • 同时也摆脱了其它语言的依赖和自我迭代

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

洋洋洒洒

暂无简介

0 文章
0 评论
24 人气
更多

推荐作者

qq_E2Iff7

文章 0 评论 0

Archangel

文章 0 评论 0

freedog

文章 0 评论 0

Hunk

文章 0 评论 0

18819270189

文章 0 评论 0

wenkai

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文