Board logo

标题: XP的命令行下不支持16位程序的中文显示? [打印本页]

作者: willsort     时间: 2004-2-6 00:00    标题: XP的命令行下不支持16位程序的中文显示?

To All:

    我的XP是2002 SP1版。但是无论进入COMMAND还是CMD,在运行16位老程序之后,都无法显示中文。比如DEBUG之类。

    不知各位有何解决之道啊?

[ Last edited by willsort on 2005-9-27 at 19:12 ]
作者: ssclose     时间: 2004-2-6 00:00
从报纸上看到的方法,xp下用turbo c通过
在cmd中输入 start/separate 路径\程序名
separate的意思是在内存中开辟一个单独的空间运行16位程序
还有个参数shared,是在共享的内存空间启动16位程序,这个没试过
你试试看
作者: Wengier     时间: 2004-2-8 00:00
Try load some Chinese system, such as CCDOS97.
作者: willsort     时间: 2004-2-8 00:00
Re ssclose:

    敬谢回复!

    此方法我以试过,总体来说,不能尽如人意。

    编了一个简单的测试批处理:

    @echo off
    echo 中文显示
    pause
    debug
    echo 显示中文

    其中DEBUG一句做过若干修改。
    ECHO Q>QUIT.ASD
    DEBUG 〈 QUIT.ASD
   不用START使用中文有问题,使用START问题更多,似乎管道符号对START很有影响,或者说START对管道符号很有影响。另外,新窗口的打开,程序的等待执行,一番参数的使用,曾使我的XP重启三次。

    看来,还是老老实实守着自己的98和DOS6吧。
作者: willsort     时间: 2004-2-8 00:00
Re Wengier:

    十分遗憾。你的方法我无法考虑,为了执行一个简单的批处理,而需要运行中文系统,即使不考虑兼容性问题,代价也是太高了。
作者: Wengier     时间: 2004-2-8 00:00
那还是老老实实地守着纯DOS系统吧。但98和DOS6都不怎么实用。MS-DOS 7.10还是兼容性最好也是最新的,毕竟现在都已经2004年了,而不是DOS6推出的1993-1994年!
作者: pizigao     时间: 2004-2-9 00:00
太遗憾了!
作者: 骨灰龙     时间: 2004-2-19 00:00
只能表示遗憾。希望将来可以做了个补丁之类的。
不过,可以通过虚拟机试试。
作者: willsort     时间: 2005-4-8 00:00
To All:

  前不久的测试中发现了一个临时解决的办法:

  1、通过command进入xp的dos控制台,然后使用graftabl 936,此时可以在16位程序中使用中文;
  2、通过cmd进入,然后分别使用chcp 437和graftabl 936,此时也可以在16位程序中使用中文;

  另外,在cmd中测试mem会只显示空行,但是一旦在其中使用debug退出后,mem就会恢复正常,其他类似的16位老dos程序也有同样的问题;也就是说,mem需要某种环境,但是只有调用类似Debug的16位程序,才能激活这种环境。它很有可能就是ntvdm的16位子环境,也就是command所激活的环境。但是为什么mem自身不会激活,还有一些程序也不会激活。

  另外,16位环境与32位环境究竟有哪些区别和联系,通过测试,已知有以下区别,大家可以再找找看:

  1、代码页:cmd是936,command是437;
  2、环境变量:cmd多于command,但command多了声卡的blaster;
  3、启动配置:command启用了config.nt和autoexec.nt;
  4、外壳层数:关闭command会提示无法结束,只有使用exit退出一层壳后,才能正常关闭;而cmd无此问题;
  5、窗口标题:cmd是命令提示符,而command是Command Prompt;

[ Last edited by willsort on 2005-9-27 at 19:13 ]
作者: willsort     时间: 2005-9-27 19:03
To All:

  有意思的是,近来不知出于什么原因,当我在“运行”中输入cmd启动命令行后,代码页变成了英文的437,而且运行mem也没有了空行闪屏问题,但是其启动后的版本LOGO却仍然显示的是XP,只不过变成了英文显示,而不是command的DOS版本显示。而即使输入cmd.exe或者c:\windows\system32\cmd.exe,也是一样的结果。

  而我在开始的附件菜单中点击“命令提示符”的快捷方式,或者找到system32下的cmd.exe直接点击,代码页都正常的显示中文。

标题:C:\windows\system32\cmd.exe
=====================
Microsoft Windows XP [Version 5.1.2600]
(C) Copyright 1985-2001 Microsoft Corp.
=====================
在“运行”中输入cmd所得到的命令行窗口

标题:命令提示符
=====================
Microsoft Windows XP [版本 5.1.2600]
(C) 版权所有 1985-2001 Microsoft Corp.
=====================
直接点击快捷方式所得到的命令行窗口

标题:Command Prompt
=====================
Microsoft(R) Windows DOS
(C)Copyright Microsoft Corp 1990-2001.
=====================
在“运行”中输入command所得到的命令行窗口

请注意它们的版权限制时间也不同。

[ Last edited by willsort on 2005-9-27 at 19:15 ]
作者: willsort     时间: 2005-10-15 11:31
Re All:

      10楼的代码页问题,经验证,是注册表中的某个项被修改,如下:

  Quote:
[HKEY_CURRENT_USER\Console\%SystemRoot%_system32_cmd.exe]
"CodePage"=dword:000001b5

其中的1b5便是437(OEM 美国)的十六进制写法。

      而9楼提到的cmd中执行mem显示空行的问题,具体描述如下:
      
      通过运行CMD或者点击菜单中命令行提示符进入命令行窗口,直接执行mem或者其它一些较老的16位DOS程序,会立即将chcp代码页切换为437,这个切换动作会进行清屏,然后显示11行空行。而如果直接执行mem>mem.txt,则切换动作仍然发生,只是显示的空行数变为1,而mem.txt中显示出11行文字。

  Quote:
Invalid keyboard code specified


    655360 bytes total conventional memory
    655360 bytes available to MS-DOS
    633664 largest executable program size

   1048576 bytes total contiguous extended memory
         0 bytes available contiguous extended memory
    941056 bytes available XMS memory
           MS-DOS resident in High Memory Area

因此有以下推测:

      1、前者的11行空行显示的正是mem.txt中的内容。
      2、mem.txt首行中Invalid一句说明程序使用了不兼容于现有Windows的Keyboard Code,而据测试还没有发现有某个16位DOS程序可以解决这种兼容问题。
      3、Code Page的强制切换可能源于这种无效的Keyboard Code。
      4、而代码页切换后程序输出尚不能正常显示,则意味着程序的输出尚不兼容于这种代码页,而DEBUG却可以进行调整。
      5、根据 Wengier 在 http://www.cn-dos.net/forum/viewthread.php?tid=1019 中的提示,在将命令行窗口全屏后,再执行 mem 等程序将不会出现猜测4所指出的问题,因此此种切换应该进行了同debug那段代码一样执行了相应的调整动作。

[ Last edited by willsort on 2005-10-15 at 12:32 ]
作者: 不得不爱     时间: 2005-10-15 12:09


  Quote:
Originally posted by willsort at 2005-9-27 19:03:
To All:

  有意思的是,近来不知出于什么原因,当我在“运行”中输入cmd启动命令行后,代码页变成了英文的437,而且运行m..

是你改变了cmd的属性引起的!如果能将属性改正常的话就没有问题了!
作者: willsort     时间: 2005-10-15 12:32
Re qwe1234567:

      那么,你尝试不通过注册表,而手动修改cmd的代码页属性,而且使这种修该对以后打开的所有命令行窗口有效。我始终找不到这个手动修改的选项入口。而删除掉这个注册表键支之后,命令行窗口就已经恢复正常了。

----------------------------------------------------------------------------------------------------
      抱歉!在我发完本帖之后,再去寻找,却意外找到了这个选项entry。

      打开命令行窗口后,先后按Alt+Space,D, 进入“控制台窗口 属性”对话框,在“选项”标签页中对“默认代码页”进行调整即可。我以前总是按Alt+Space,D,结果总是进入“C:\windows\system32\cmd.exe”属性 对话框,其中的代码页是不可调整的。

      但是,这个选项修改的是所有控制台的代码页,对应的注册表键支是:

  Quote:
[HKEY_CURRENT_USER\Console]
"CodePage"=dword:000003a8

而原来的[HKEY_CURRENT_USER\Console\%SystemRoot%_system32_cmd.exe]不知是如何被创建的。


[ Last edited by willsort on 2005-10-15 at 12:50 ]
作者: 不得不爱     时间: 2005-11-3 21:26
还有一个办法就是写一个REG文件,在CMD有问题时导入即可!
作者: electronixtar     时间: 2007-2-11 14:28

chcp 437>nul&graftabl 936>nul
http://www.cn-dos.net/forum/viewthread.php?tid=26795

WillSort 兄的确厉害!!!怀念ing...
作者: 不得不爱     时间: 2007-8-11 10:26
原来的[HKEY_CURRENT_USER\Console\%SystemRoot%_system32_cmd.exe]是你在标题名为:%SystemRoot%\system32\cmd.exe的窗口里设置属性并应用于具有相同标题的窗口后出现的,
而"CodePage"=dword:000001b5是你在设置默认属性并应用于具有相同标题的窗口后出现的!
作者: koala     时间: 2007-8-14 16:10    标题: XP下的16位程序兼容性

经常下载dos软件用,好多时候我的
dos虚拟机(xp自带)老容易崩溃,
看了上面文章,很好!学习了!
作者: baoaabao     时间: 2008-2-15 12:23
WillSort  终于解决了我乱码的问题,万分感激阿