这个问题很有意思:
C 语言的编译器,是用 C 语言写的。
什么?C 语言是用 C 语言写的,这不就是“鸡生蛋,蛋生鸡”的问题吗?
要让 C 语言编译通过,就需要一个 C 语言编译器。但是 C 语言编译器是用 C 写的。那么世界上第一个能执行的编译器,是如何编译的呢?
这种编译器也用语言本身写的特性,称之为“自举”。
奇怪的是,这么一个让我们纳闷的问题,却很少有人提到。似乎大神们觉得很自然,不屑于说明。
直到后来学到一些编译相关的技术,才慢慢了解到这件事的原委。原因不复杂,我简化一下表述:
为什么要分 N 个步骤呢?主要还是为了解释 C 语言慢慢进化的历史过程。实际上不见得要分很多步,很多中间步骤只是代表了远古大神们迭代改进的过程。
如果大神足够神,可以更简化:
然后,那个用汇编语言写的版本就可以扔掉了。
如果你觉得这个故事有点意思,说明你可能是对编程感兴趣的人 :)。
理解这个问题的关键,是认识到:编译器,只是读取文本文件(源代码),输出某种计算机编码(比如机器语言)的程序。
既然编译器也只是个普通的程序,那么就能用任何语言编写。
所以,理论上来讲,你可以用 Python、Java 或者 Scratch 来写个 C 语言编译器【捂脸】。