怎么解决ASICII>128时,输出是汉字和问号的问题
对于ASICII>128时,输出是汉字和问号。怎么解决?我是初学者。 就是这个题,我无法输出图案,只有汉字和问号。题目:输出特殊图案,请在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);}
最大就只有127
无我的侠圣 发表于 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 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]