微软公司成立几十多年了
源代码是如何确保没有泄露的
源代码外泄就会像LINUX一样有无数个山寨WINDOWS系统
假如WINDOWS是用C语言编写的
那么是在什么操作系统下编写的呢
如果是在DOS系统
DOS系统又是在什么系统编写的呢
C语言又是用什么语言编写的呢
你的一个问题中包含三个问题,我先回答第一个:
Windows XP系统源代码通过4chan匿名论坛外泄,时间发生在2020年,当时有用户将泄露的代码成功编译成可运行的操作系统。
所以Win源码是有泄露的,微软在保密这方面做得并不好。至于为何没有山寨系统,一是因为有法律风险,二是山寨的系统没有持续的更新和保障。确实可以用XP泄露源码山寨,但是谁会用呢?Win10随便就能破解激活,没有必要用山寨。
第二个问题,DOS系统又是在什么系统编写。
MS-DOS 的开发是在 CP/M(Control Program for Microcomputers)操作系统下进行的。CP/M 是当时非常流行的操作系统,运行在 Intel 8080 和 Zilog Z80 微处理器上。开发者使用 CP/M 环境中的文本编辑器和编译器来编写 MS-DOS 的代码。
第三个问题,C语言本身是用什么语言写的。
C 语言的编译器,是用 C 语言写的。
什么?C 语言是用 C 语言写的,这不就是“鸡生蛋,蛋生鸡”的问题吗?
要让 C 语言编译通过,就需要一个 C 语言编译器。但是 C 语言编译器是用 C 写的。那么世界上第一个能执行的编译器,是如何编译的呢?
这种编译器也用语言本身写的特性,称之为“自举”。
奇怪的是,这么一个让我们纳闷的问题,却很少有人提到。似乎大神们觉得很自然,不屑于说明。
直到后来学到一些编译相关的技术,才慢慢了解到这件事的原委。原因不复杂,我简化一下表述:
- 首先,简化 C 语言的设计,只选择最最基本、不得不实现的功能,形成一个 C 语言的子集。我们可以叫它 C0。
- 用汇编语言实现 C0 语言的编译器,由于 C0 功能很少,比较容易直接写一个编译器。
- 用 C0 语言去实现更多必要的功能,由于 C0 语言功能太弱,遇到不好写的地方可以用汇编来打补丁。最终你得到了一个改进版的 C0 语言,我们称之为 C1。
- 用 C1 语言去继续实现更多 C 语言功能,不好写的地方继续用汇编打补丁。可以得到 C2 语言
- 用 C2 语言去继续实现更多 C 语言功能,不好写的地方继续用汇编打补丁。可以得到 C3 语言
- 以此类推……
- 到 Cn 语言的时候,你已经得到了一个足够接近 C 语言的编译器。
- 继续迭代一两次……
- 终于,你得到了一份 C 语言的编译器。而前面的从 C0 版到 Cn-1 版的编译器,都可以扔掉了。
为什么要分 N 个步骤呢?主要还是为了解释 C 语言慢慢进化的历史过程。实际上不见得要分很多步,很多中间步骤只是代表了远古大神们迭代改进的过程。
如果大神足够神,可以更简化:
- 直接用汇编语言写一个 C 语言编译器。
- 然后再用 C 语言写一个 C 语言编译器的源码,用汇编版的编译器 编译这个 C 代码
- 即可得到一个可运行、可正常使用的编译器。
然后,那个用汇编语言写的版本就可以扔掉了。
如果你觉得这个故事有点意思,说明你可能是对编程感兴趣的人 :)。
理解这个问题的关键,是认识到:编译器,只是读取文本文件(源代码),输出某种计算机编码(比如机器语言)的程序。
既然编译器也只是个普通的程序,那么就能用任何语言编写。
所以,理论上来讲,你可以用 Python、Java 或者 Scratch 来写个 C 语言编译器。
以上应该全部解答你的问题了,下次不要俄罗斯套娃了,三个不同的问题可以分开提问哦。