无我的侠圣 发表于 2017-1-15 11:19:25

怎么解决ASICII>128时,输出是汉字和问号的问题

对于ASICII>128时,输出是汉字和问号。怎么解决?我是初学者。

无我的侠圣 发表于 2017-1-15 11:26:19

就是这个题,我无法输出图案,只有汉字和问号。
题目:输出特殊图案,请在c环境中运行,看一看,VeryBeautiful!
1.程序分析:字符共有256个。不同字符,图形不一样。      
2.程序源代码:
#include "stdio.h"
main()
{
char a=176,b=219;
printf("%c%c%c%c%c\n",b,a,a,a,b);
printf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",a,a,b,a,a);
printf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",b,a,a,a,b);}

人造人 发表于 2017-1-15 17:27:07

最大就只有127

zealstar 发表于 2017-1-15 17:49:48

无我的侠圣 发表于 2017-1-15 11:26
就是这个题,我无法输出图案,只有汉字和问号。
题目:输出特殊图案,请在c环境中运行,看一看,VeryBeaut ...

这跟你的系统环境有很大关系!
标准的ASCII编码只有0~127一共128个字符,每个字符占1字节!
只有扩展的ASCII编码才有128~255的后127个字符!
即:ISO-8859-1字符集 {:10_334:}

而我们的系统多半使用的是GB18030字符集 :
作用:它解决了中文、日文、朝鲜语等的编码,兼容GBK。
位数:它采用变字节表示(1 ASCII,2,4字节)。可表示27484个文字。
范围:1字节从00到7F; 2字节高字节从81到FE,低字节从40到7E和80到FE;4字节第一三字节从81到FE,第二四字节从30到39。

你可以发现,低位字节只要超过7F(127),则切换为中文识别!而中文占2个字节!
所以,所谓乱码即超出GB18030字符集范围的字符,或者,大于7F而缺少后一个字节的值的字符就显示了“?”{:10_277:}

处理办法:
1、printf("%c %c %c .....", .....)                将字符之间加上空格,这样就不会将字节连起来输出,当然,前提是你的系统的编码支持ASCII扩展!
2、把这个程序放到linux环境去编译   linux一般都是使用utf-8编码(所谓的万国编码,每个字符3个字节,基本解决了乱码问题)
3、把你的系统换E文试试                        E文系统一般都支持ASCII扩展

本来还有个题外话,如果不是微软目中无“国”,我们的系统早就应该是UTF-8编码的!!!
而现在,实际情况是GB18030,BIG5,GBK,UTF-8混用…………你去韩国就乱你的码,你去日本乱你的码,你特么去了欧洲,碰到超过127的单字节,特么又乱…………{:10_285:}

无我的侠圣 发表于 2017-1-15 19:52:44

本帖最后由 无我的侠圣 于 2017-1-15 20:04 编辑

感谢zealstar的解答。改了一下程序,解决了。
#include <stdio.h>
#include <windows.h>
void main()
{
        char a=176,b=219;
      SetConsoleOutputCP(437);
        printf("%c%c%c%c%c\n",b,a,a,a,b);
        printf("%c%c%c%c%c\n",a,b,a,b,a);
        printf("%c%c%c%c%c\n",a,a,b,a,a);
        printf("%c%c%c%c%c\n",a,b,a,b,a);
        printf("%c%c%c%c%c\n",b,a,a,a,b);
}
页: [1]
查看完整版本: 怎么解决ASICII>128时,输出是汉字和问号的问题