COMMAND.COM是Windows 9X中的DOS外壳程序(SHELL),较DOS 6.22仅增加了部分内部命令,没有更新的东西。
IO.SYS对COMMAND.COM的处理则有了根本改变,当Win 9X在CONFIG.SYS中加载EMM386.EXE驱动提供UMB时,COMMAND.COM的常驻部分装入HMA,暂驻部分装入UMB中(在DOS6.22中,COMMAND.COM只能将常驻部分装入HMA),这将为DOS程序提供更大的常规内存,也不需要反复从磁盘中恢复暂驻部分,有效地提高了系统性能。当然,如果没有加载EMM386.EXE,系统不提供UMB,COMMAND.COM的暂驻部分就只能象DOS6.22那样置于常规内存的高端。
六、CONFIG.SYS和AUTOEXEC.BAT
Win 9X中的CONFIG.SYS、AUTOEXEC.BAT的作用与DOS的一样,用于装配所有DOS实模式的驱动程序和应用程序,或者修改IO.SYS的默认配置。其中,CONFIG.SYS主要用于硬件配置,AUTOEXEC.BAT主要用于软件配置,其在启动过程中的使用参见IO.SYS一节。
Win 9X启动后,这两个文件的配置作为全局设置始终保留在系统底层,决定着Win 9X下所有的DOS、Win 16应用环境。如果没有DOS全局设置,Windows窗口下的DOS应用程序将使用Win 9X的默认设置,当然也可由用户单独配置。注意,DOS软件需要的PATH、SET等环境设置可在各自窗口的属性中单独设置;16位的Win 3.X软件需要的PATH、SET等环境设置只能在AUTOEXEC.BAT中设置。
Win 9X新增了不少配置命令,使实模式DOS环境更便于优化,各配置命令参见系统目录Windows下的CONFIG.TXT说明,这里不再多说。 Win 9X通过VXD(虚拟设备驱动)、DLL(动态链接库)等保护模式驱动程序统一管理和使用系统软、硬件资源,基本上不需要实模式程序支持。实模式程序主要是为支持一些老设备而保留的。实模式程序的存在使Win 9X必须在保护模式和实模式之间频繁地转换,大大降低了系统性能,更损害了系统稳定性,所以应尽量避免在启动时装载实模式程序。
Win 9X对DOS环境的缺省设置能满足大多数DOS软件需要,在完成Win 9X安装后试着删除这两个文件中的内容非常必要。删除其中的实模式程序,尽量实现Win 9X的保护模式驱动,可使Win 9X处于高性能、高稳定性的优化运行状态。
没有CONFIG.SYS、AUTOEXEC.BAT的DOS系统几乎一无所能,而没有它们的Win 9X性能也许更好。在Win 9X中它们主要是为支持原DOS软件和古老的设备而保留的。目前多数报章建议完全删除这两个文件,这其实很有问题,具体分析参见《电脑界·电脑高手》'99年10月号。
七、Win.COM
Win.COM是Windows的GUI启动命令,从文件名可以看出这是一个纯粹的DOS命令,它也是GUI系统中唯一的COM文件。该命令是DOS和GUI的接口命令,主要用来加载保护模式的虚拟设备驱动程序VMM32.VXD(该程序是由多个子程序组合而成的,使CPU运行于保护模式下),同时处理GUI启动中的各种问题,它控制着系统的整个调入过程。
Win.COM提供的各类启动开关,主要用于确定系统故障,会使系统性能降低:
Win [/D: [F][M][S][V][X]]
/D 当Windows不能正常启动时用于查找故障原因
:F 关闭32位磁盘存取模式,用于不支持32位存取的硬盘
等价于在SYSTEM.INI的[386ENH]节中设定: 32BitDiskAclearcase/" target="_blank" >ccess=FALSE.
:M 安全模式启动,等价于使用功能键F5启动
:N 带实模式网络支持的安全模式启动,等价于使用功能键F6启动
:S 禁止Windows使用在F000:0000与1 MB之间的ROM地址空间做为断点
等价于在SYSTEM.INI的[386ENH]节中设定: SystemROMBreakPoint=FALSE.
:V 指定启动时由ROM例程处理硬盘控制器中断
等价于在SYSTEM.INI的[386ENH]节中设定: VirtualHDIRQ=FALSE.
:X 禁止Windows使用所有高端内存(从A000-FFFF),解决内存冲突问题
等价于在SYSTEM.INI的[386ENH]节中设定: EMMExclude=A000-FFFF.
八、GUI启动
Win 9X的GUI启动过程是非常复杂,更是微软公司的核心秘密,不为外人所知。而对普通用户而言,完全掌握这个复杂多变的机制也无必要,这里只对整个GUI启动机制做一个大致的说明。
1、GUI的配置文件
同所有复杂的系统一样,Win 9X主要是根据系统配置文件调用各类程序来组合系统,保证系统正常运行的。Win 9X的GUI系统配置文件以系统注册表为核心,以各系统目录下的INI文件为辅助配置。把握住系统配置文件,就掌握了系统的核心。
GUI系统的核心配置文件主要有5个,即:Win.INI、SYSTEM.INI、SYSTEM.DAT、USER.DAT和POLICES.DAT。
Win.INI和SYSTEM.INI据说是为Win 3.X下的Win 16保护模式程序保留的,Win 3.X在这两个文件中的设置在Win 9X中大部分已移入系统注册表中。Win 9X下Win 32保护模式程序主要通过系统注册表完成配置,不需要这两个文件的支持。这一做法规范了应用程序的开发和使用,消除了随意设置INI文件的混乱,便于Win 9X统一管理系统,增加了系统的稳定性。但如果删除这两个文件,Win 9X系统无法启动,并提示“找不到SYSTEM.INI文件”,这说明Win 9X的启动还是离不开这两个文件的。
Win.INI提供了Win 16程序需要的字体设置、文件关联等种种信息,主要完成GUI下相应的环境配置,对Win 9X应用没有太大影响,如果没有这个文件,Win 9X将自动生成一个最简单的只有几行配置命令的Win.INI。
SYSTEM.INI则不同,它是Win 16的系统硬件配置文件,Win 9X又为其增加了一些新设置,以保证Win 16和Win 32相互协调,使Win 16可以调用VXD驱动程序,这一点在Win.COM提供的系统调试参数中已有充分体现。另外GUI的外壳程序(SHELL,即界面程序)、鼠标器、显示器等驱动程序必须通过SYSTEM.INI设置才能加载使用,这些决定了SYSTEM.INI是绝对不能删除的。这充分证明了Win 9X是一个Win 16和Win 32的混合系统,也揭示了Win 9X系统先天脆弱的根本原因。
SYSTEM.DAT和USER.DAT即所谓的系统注册表文件,是Win 9X的核心文件,Windows就是通过它来管理整个系统的。SYSTEM.DAT保存着硬件配置及软件安装信息,USER.DAT保存着与用户的个人设置有关的信息,前者只能有一个,而后者可以有多个。这两个文件共同作用,包含了系统的全部信息,在使用注册表编缉软件(如REGEDIT.EXE)时,这两个文件共同被修改,不能分开。它们的损坏将导致系统彻底瘫痪,无法挽救。不幸的是,系统注册表非常脆弱,缺乏自我整理和维护机制,当系统运行一段时间后,用户往往只能走上痛苦的系统重建之路。
在Win 95/96/97中,注册表的备份为SYSTEM.DA0和USER.DA0,保存在Windows下;在Win 98中,Win.INI、SYSTEM.INI、SYSTEM.DAT和USER.DAT四个文件被合并备份成一个文件RB00?.CAB,保存在WindowsSYSBCKUP下,默认保留5个。
每次GUI启动时系统会对备份文件自动更新,这种处理缺乏安全管理机制,难以保证备份文件不受错误信息干扰,多数情况下备份文件形同虚设。
令人遗憾的是,除了手工编缉注册表软件REGEDIT.EXE,Win 9X没有提供更有效的注册表维护工具。在Win 98提供了注册表检测软件ScanReg.exe和ScanRegw.exe,这是一个进步,但它只能处理注册表的物理故障,无法解决结构性问题,其可靠性又有多大呢?
博大的注册表完全应该用一本专著来剖析,在《新潮电子精华本1》中也有简单的介绍,这里就不做更深的解释了。
POLICES.DAT是微软的MSN(Microsoft Network)注册支持文件,该网络国内用户很少,该文件也很少使用。
尽管没有更直接的资料介绍,但是有充分的理由证明在Win 9X的启动过程中,保存在WindowsINF目录下的各种INF文件是Win 9X系统中最有力的支持文件。在启动系统的过程中,Win 9X会适时地调用这些文件,以装载相应的驱动程序。如果没有了这些文件,Win 9X也是无法启动的。另外,Win 9X的PNP技术主要是通过INF文件实现驱动程序安装的。