【c++】wchar_t的详细教程,关于wchar_t使用wcout编译运行输出结果为空以及为乱码类似O的解决办法....
一、wchar_t:
百度百科:
wchar_t是C/C++的字符类型,是一种扩展的存储方式。wchar_t类型主要用在国际化程序的实现中,但它不等同于unicode编码。unicode编码的字符一般以wchar_t类型存储。
char是8位字符类型,最多只能包含256种字符,许多外文字符集所含的字符数目超过256个,char型无法表示。
wchar_t数据类型一般为16位或32位,但不同的C或C++库有不同的规定,如GNU Libc规定wchar_t为32位,总之,wchar_t所能表示的字符数远超char型。
标准C中的wprintf()函数以及标准C++的iostream类库中的类和对象能提供wchar_t宽字符类型的相关操作。
二、wchar_t使用wcout编译运行后结果为空以及解决办法:
1、编译后输出结果为空效果图如下:
2、原因分析:
由于每个国家显示的文字是不同的。
3、解决办法:
添加头文件#include <locale>
以及setlocale(LC_ALL,"chs");
//转换为中文字符
,如下图:
添加代码块①和②到代码中,此时可以输出结果来了。但是由于手贱(在wcout后面添加了一串文字)引发了③的错误出来。解决办法往下看????↓
三、输出结果为乱码类似O的解决办法:
解决办法有两点:
1、删除wcout后的一串文字, 如下图:
此时已经可以正常输入文字了,不再是乱码了。
2、在wcout后的一串文字的引号前添加L,(注意,是文字的引号前,引号前添加L) 如下图:
ok,使用以上方法,完美解决乱码问题!!
--------------------------------------------------人生在勤,不索何获。------------------------------