您的位置:首页 > 移动开发

bootstrapping 自举

2016-06-02 20:38 951 查看
bootstrapping

字面上的解释: boot为靴子,strap为带子(这里即为鞋带),bootstrapping为系鞋带?

某百科给出的解释:

拔靴法:所谓的拔靴法就是利用有限的样本资料经由多次“重复抽样”,重新建立起足以代表母体样本分布之新样本。

而程序界则称:

自举:程序语言编译器用自身的语言及其特性来编译自己。换句话说就是,使用这个语言的一些特性来编写编译器并使该编译器中支持这些自己使用到的特性。此为编译原理中一个很重要的部分。对于很多新新的语言如go,rust等,通过自检能使编译器获得新的特性外,语言开发者也能从中大量的使用新的语言,更有利于新语言的改进和发展。

来自网络的一个通俗的解释:
https://segmentfault.com/q/1010000000692678/a-1020000000693031
首先,第一个编译器肯定是用别的语言写的(不论是C还是Go还是Lisp还是Python),后面的版本才能谈及自举。至于先有鸡还是先有蛋,我可以举个这样的不太恰当的例子:比如我写了一个可以自举的C编译器叫作mycc,不论是编译器本身的执行效率还是生成的代码的质量都远远好于gcc(本故事纯属虚构),但我用的都是标准的C写的,那么我可以就直接用gcc编译mycc的源码,得到一份可以生成高质量代码但本身执行效率低下的mycc,然后当然如果我再用这个生成的mycc编译mycc的源码得到新的一份mycc,新的这份不光会产生和原来那份同等高质量的代码,而且还能拥有比先前版本更高的执行效率(因为前一份是gcc的编译产物,后一份是mycc的编译产物,而mycc生成的代码质量要远好于gcc的)。故事虽然是虚构的,但是道理差不多就是这么个道理。这也就是为什么如果从源码编译安装新版本的gcc的话,往往会“编译——安装”两到三遍的原因。

小小的p.s.

从这个例子我开始想起,自举给我最深的影响是自己尝试用C自举了__cdecl的一部分功能。这是用C语言编译出自己的编译器的一个自举的很好的例子 :)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: