【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、编译后输出结果为空效果图如下:

【c++】wchar_t的详细教程,关于wchar_t使用wcout编译运行输出结果为空以及为乱码类似O的解决办法....
2、原因分析:
由于每个国家显示的文字是不同的。

3、解决办法:
添加头文件#include <locale>以及setlocale(LC_ALL,"chs"); //转换为中文字符,如下图:

【c++】wchar_t的详细教程,关于wchar_t使用wcout编译运行输出结果为空以及为乱码类似O的解决办法....
添加代码块①和②到代码中,此时可以输出结果来了。但是由于手贱(在wcout后面添加了一串文字)引发了③的错误出来。解决办法往下看????↓

三、输出结果为乱码类似O的解决办法:

解决办法有两点:


1、删除wcout后的一串文字, 如下图:
【c++】wchar_t的详细教程,关于wchar_t使用wcout编译运行输出结果为空以及为乱码类似O的解决办法....
此时已经可以正常输入文字了,不再是乱码了。

2、在wcout后的一串文字的引号前添加L,(注意,是文字的引号前,引号前添加L) 如下图:
【c++】wchar_t的详细教程,关于wchar_t使用wcout编译运行输出结果为空以及为乱码类似O的解决办法....

ok,使用以上方法,完美解决乱码问题!!

--------------------------------------------------人生在勤,不索何获。------------------------------