写点什么

时隔 35 年后,复古计算爱好者让 Windows 1.0 “重生”

  • 2020-06-03
  • 本文字数:3182 字

    阅读完需:约 10 分钟

时隔 35 年后,复古计算爱好者让 Windows 1.0 “重生”

本文最初发表在 The New Stack 网站,经原作者 David Cassel 授权,InfoQ 中文站翻译并分享。


导读:复古计算(Retrocomputing)是一个文化话题,复古计算社区是相当多元化的国际社区,容纳了许多不同文化背景的爱好者。以目前的电脑硬件的性能来看,现代电脑硬件的性能不仅可以模拟大多数的古董电脑,甚至早已远远超越。有这么一个复古计算爱好者,就进行了一次伟(wu)大(liao)的尝试:让 35 年前的 Windows 1.0 “重生”,并尝试了在 Windows 1.0 编写的程序能不能在 Windows 10 上运行。究竟还能不能运行呢?让我们来看看本文!


35 年前,在 Windows 上进行编程是什么样的体验?


有这么一个人,为了找出这个答案,决定亲自尝试。


纽约开发人员 Michael Casadevail 就是这样的人,他一路冒险,追溯到 Microsoft 发布第一个基于 GUI 的操作系统 Windows 1.0 之时,他构建了一个虚拟系统,在这个虚拟系统中,他可以安装 1985 年的原始软件开发工具包,然后研究了一个简单的“Hello World”程序附带的传奇示例代码。


Casadevall 那一场令人着迷的实验,让我们得以能够一瞥 Windows 最初的起源,不仅显示了这 35 年来,事情发生了多大的变化,而且也显示了有多少东西被保留了下来。


当然,追溯这一过程也是乐趣所在。

历史重演

Casadevall 使用的是 Oracle 的 X86 虚拟化工具:Oracle VM VirtualBox,在虚拟机中,他先加载了 IBM 的 PC DOS 3.3,而不是微软的 MS DOS 3.3。他在 Soylent News 的一篇文章中指出:“我这样做的原因是,当时的 DOS 还不是一个独立的产品,相反的是,Microsoft 将授权 DOS OEM 适配开发套件,需要原始设备制造商(Original Equipment Manufacturer,OEM)创建自己的 DOS,如 Compaq DOS 3.3。”


很显然,为了这次实验,Casadevall 带来了很多技术上的专业知识。他在自己的推特个人资料上将自己描述为 “复古计算爱好者” 和 “狂热的信息安全黑客”。


“我个人对复古计算很感兴趣,这已经不是什么秘密了, ” Casadevall 在网站上写道,“我还记录了个人电脑的历史和演变史。” 在后来的一段视频中,他称自己是 “90 年代的孩子”。有一年圣诞节,他惊讶地发现,自己居然还有一台运行 Windows 3.1 的 Packard Bell 计算机。


但为了做出这一段视频,Casadevall 回到了更远的过去……


这个项目给 Casadevall 带来了一些挑战。


Casadevall 写道:“Windows 1.0 早在鼠标作为计算机硬件标准部件出现之前就已经存在了。” 事实上,很早的时候,Casadevall 就发现自己无法模拟出串行或总线鼠标。他想出了一个解决办法,将鼠标驱动从 Windows 2.0 安装软盘复制到 Windows 1.0 安装软盘上,这样,鼠标就可以在设置屏幕上显示为一个选项。


Casadevall 在 Soylent News 上写道:“第二个选项,我直到制作完视频才知道,是使用 PS/2 版本的 Windows 1.0。就像那个时代的 DOS 一样,Windows 也是授权给原始设备制造商,原始设备制造商可以根据自己的硬件进行调整。” 这是一个被遗忘的时代,它是如此原始,以至于 Windows 仍然必须通过键入 win 命令从 DOS 命令行来启动。Casadevall 写道,“有传闻称,Windows 将被移植到 XENIX 上运行,XENIX 是 Microsoft 基于 UNIX 的操作系统。”


当然,至少有一些更简单的方法可以做到这一点。你可以使用 PCjs.org 这个网站,它是基于浏览器的仿真器,已经提供鼠标的支持。


他称 Windows 1.0 “本质上就是 DOS 的图形化程序,不过,通过深奥的魔力,它能够协同多任务处理。这完全是通过软件技巧来完成的……”

DISK 2 有什么?

在对磁盘进行分区并安装 DOS 和 Windows 1.0 之后,是时候设置开发环境了。Casadevall 写道:“不幸的是,网上几乎没有关于如何做这件事的文档。” 但幸运的是,OS/2 博物馆扫描了一些原始的参考文件夹,“在仔细检查磁盘时,我发现了一个安装批处理文件”,它的起名恰如其分,就叫 install.bat ,并提醒用户必须有至少 512K 的内存。此外,还需要一个软盘驱动器,配置为驱动器 A,以及图形监视器(单色或彩色均可)。


“如果你没有上述设备或软件,请放弃该批处理文件,” 文档警告称,“建议使用鼠标,但非必需。”


在 Soylent News 上的帖子中,他提到了更详细的界面,“这样的改进很可能是因为大多数用户希望自己安装 Windows,而不是预装……”


但这是对那个世界的一瞥,在那里并没有网页分享相关信息。有关软件开发工具包中文件的完整列表,请参阅 Disk 2 的 FILELIST.TXT 文件。


“由于可能只有在 1985 年才有意义的原因,脚本和 README 自述文件都放在 Disk 2 上,而不是放在 Disk 1。”


事实上,SDK 分布在 7 张软盘上,其中 4 张软盘需在安装过程中插入。当然,这一切插入行为都是由名为install.bat 的文件触发的。



第五张软盘有 Windows 内核的调试版本,其余两张磁盘有示例编程代码,包括 Hello World 示例。


而且用户还需要执行更多的安装。“与后来的 SDK 版本不同的是,程序员有责任提供编译器……” 他在帖子指出。安装屏幕提示支持三个选项:


  • Microsoft C compiler, version 4.0

  • Microsoft Pascal compiler, version 3.3 or later

  • Microsoft Macro assembler, version 4.0


Casadevall 写道,“非官方的(以及非经正式的),Borland C 的一些版本也可以用,尽管这没有经过测试,除了在新闻组上的一些注释外,似乎并没有人做出任何记录。更有趣的是,上述所有工具都是针对 DOS 的编译器,对 Windows 没有任何特定的支持。”


Casadevall 在视频中指出,要找到 Microsoft C 4.0 并不难,不过,他需要再看一遍用户手册,才能知道正确的安装方法。由于硬盘在 1985 年还不常见,因此 Microsoft 支持通过软盘运行编译器。硬盘安装需要编辑这些关键的文件:CONFIG.SYSAUTOEXEC.BAT,以及手动复制所有必需的库和可执行文件。


编写代码还涉及到处理近指针(功能上与给定段内的普通 C 指针相同)和远指针(8086 具有使用这些指针的特殊操作码)。


“回调函数总是必须声明 FAR,因为 Windows 在从任务管理器中跳转到应用程序代码时,需要加载正确的段。”


此外,Windows 1 清理堆栈的方式也有一些奇怪之处。


Casadevall 指出,16 位 Windows 应用程序 “普遍存在于共享地址空间中”,当时的 Windows 并不会立即回收标记为未使用的内存。即使在应用程序被终止后,它的某些部分仍然会保留在内存中。


尽管如此,经过多次通过软驱交换软盘和一些故障排除之后,Casadevall 使用文本编辑器编写了一个快速的 Hello World 程序(用 C 语言编写),然后用 Microsoft 的 C 语言编译器进行编译。显然,它创建了一个 .exe 版本的文件,只需键入文件名 “hello” 而无需后缀名即可执行。该程序将立即打印出 NCommander 的测试信息。


“来自 DOS 的问候。”

向下兼容性怎么样?

Casadevall 还想尝试另一个实验:为 Windows 1.0 编写的 “Hello World” 程序,在现代系统上还能运行吗?


一些研究表明,通过运行 NT 虚拟 DOS 模型(即 NT virtual DOS mode ,NTVDM)与 Windows 的子系统(Windows on Windows,称为 “Wow”),可以实现对旧版 DOS 和 16 位 Windows 程序的兼容性。Casadevall 指出,即使到了今天,NTVDM 仍然是 Windows 10 某些版本的一部分,不过他指出,Windows 10 转向 64 位时已经完全放弃了对传统 16 位的支持,并且不包括 NTVDM。


但 Microsoft 仍然提供了 32 位版本的 Windows 10,其中仍然包括 NTVDM。Casadevall 获取了现在的 Windows 10 1909 版,并将其安装到虚拟机中,然后试图运行他为 Windows 1 编写的 “Hello World” 应用程序。他写道:“双击 hello.exe 时,会提示 Windows 需下载并安装 NTVDM,这第一步就让人看到了希望。在进行第二次的尝试时,我可以确认,这是有可能实现的!”


“长达 35 年的向下兼容性!”



译注:有关 Windows 10 的 NTVDM 和 16 位应用程序的支持,请参阅 Microsoft 的官方文档说明:NTVDM and 16-bit app support


原文链接:


https://sourl.cn/Lp7QPP


2020-06-03 09:002078

评论

发布
暂无评论
发现更多内容

官方线索|2021科大讯飞全球开发者大会

搬砖人

AI 大会 1024我在现场

java springboot自习室选座预约小程序源码

清风

计算机毕业设计

无处不在的Kubernetes ,难用的问题解决了吗?

望宸

容器 云原生 PaaS KubeVela kubenetes

华为云企业级Redis:助力VMALL打造先进特征平台

华为云开发者联盟

华为云 云数据库 GaussDB(for Redis) 华为商城 VMALL

技术干货 | jsAPI 方式下的导航栏的动态化修改

蚂蚁集团移动开发平台 mPaaS

容器 大前端 移动开发 mPaaS 动态化

架构设计系列五 如何设计业务高性能高可用计算架构

nydia

架构实战营模块五作业 - 设计微博系统中”微博评论“的高性能高可用计算架构

李焕之

基于HarmonyOS分布式技术,这群学生赋予冰箱更智能的体验

科技汇

iOS签名校验那些事儿

百度Geek说

后端

Apache APISIX 社区新里程碑——全球贡献者突破 300 位!

API7.ai 技术团队

开源社区 API网关 Apache APISIX

怎样才能画出清晰明了的时序图

华为云开发者联盟

接口 模型 UML 系统 时序图

腾讯云,五轮面试,六个小时,灵魂拷问,含泪拿下 60W offer

收到请回复

Java 面试 大厂Offer

阿里大牛珍藏版:高并发系统设计(全彩版手册)带你从基础走向实战

Java 架构 面试 后端 高并发

☕【Java技术指南】「技术盲区」看看线程以及线程池的异常处理机制都有哪些?

码界西柚

Java 线上程序问题 线程异常 10月月更

这篇 python 文章,是过去你错过的 python 细节知识点,滚雪球第4季第15篇

梦想橡皮擦

10月月更

Apache APISIX 社区周报 | 2021 9.13-9.30

API7.ai 技术团队

开源社区 api 网关 社区周报 Apache APISIX

【万字长文】吃透负载均衡

Java 负载均衡 架构 面试 后端

这几种Java异常处理方法,你会吗?

华为云开发者联盟

Java 数组 异常 程序

开源许可协议介绍

webrtc developer

云小课丨SA基线检查:给云服务来一次全面“体检”

华为云开发者联盟

态势感知 华为云 基线检查 SA 上云合规

【LeetCode】外观数列Java题解

Albert

算法 LeetCode 10月月更

看动画学算法之:平衡二叉搜索树AVL Tree

程序那些事

数据结构 算法 二叉树 程序那些事

10 月 30 日 北京 LiveVideoStack 阿里云视频云专场限量赠票 100 张

阿里云CloudImagine

阿里云 音视频 高清视频 视频编解码 视频云

阿里开源的这个库,让 Excel 导出不再复杂(填充模板的使用指南)

看山

Java EasyExcel 10月月更

Vue进阶(幺叁捌):vue 路由传参的几种基本方式

No Silver Bullet

Vue 路由 10月月更

新书榜第一的《图解产品》,帮助内卷中的产品经理实现跨越式发展!

博文视点Broadview

产业互联网下半场,SaaS平台的机遇与挑战

雯雯写代码

SaaS

秀到飞起!Alibaba全新出品JDK源码学习指南(终极版)限时开源

收到请回复

Java jdk 面试

Python代码阅读(第38篇):根据谓词函数和属性字符串构造判断函数

Felix

Python 编程 Code Programing 阅读代码

【Flutter 专题】28 易忽略的【小而巧】的技术点汇总 (五)

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 10月月更

Apache APISIX 社区成员助力 openEuler 发布第一个社区创新版

API7.ai 技术团队

开源 openresty openEuler api 网关 Apache APISIX

时隔 35 年后,复古计算爱好者让 Windows 1.0 “重生”_语言 & 开发_David Cassel_InfoQ精选文章