宽字符的设置,需要注意的有以下几点:
1: 使用中文必须本地化 */所以需要加入头文件 #include<locale.h> 还要在代码中设置本地编码 setlocale(LC_ALL, "zh-CN");
2: 在宽字符中,字符都占 2 个字节
3:乱码的原因、经常出现的码就是不明的解析方式造成的
1):设置本地化 #include<locale.h>
2):设置本地编码解析方式setlocale(LC_ALL, "zh-CN");
以下代码是对单个宽字节使用:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
/* 使用中文必须本地化 */
#include<locale.h>
/* 在宽字符中,字符都占 2 个字节 */
/*
#include<locale.h>
setlocale(LC_ALL, "zh-CN");
设置中文,经常出现的码就是不明的解析方式造成的
*/
void main()
{
/* 设置中文,经常出现的码就是不明的解析方式造成的 */
setlocale(LC_ALL, "zh-CN");
wchar_t wch = L'我';
putwchar(wch);
system("pause");
}
求宽字符与普通的字符所对应的ACSII有什么不同:
无论是宽字符还是窄字符,ASCII都是一样的,只是所使用的内存空间不一同,即装他们的盒子大小不一样,但是ASCII值是一样的。
看下面的代码:
void main()
{
/* 设置中文 */
//setlocale(LC_ALL, "zh-CN");
wchar_t wch = L'A';
/* 一字汉字占二个字节 */
char ch = 'A';
/* 都是65 无论是宽字符还是窄字符,ASCII都是一样的,只是所使用的内存空间不一同
即装他们的盒子大小不一样,但是ASCII值是一样的。
*/
printf("%d, %d", ch, wch);
system("pause");
}
/* 求宽字符串的长度 */
int mywcslen(const wchar_t *str)
{
int sum = 0;
/* 都要使用宽字符标示 */
while (*str != L'\0')
{
str++;
sum++;
}
return sum;
}
/* 宽字符串 */
void main()
{
/* 设置中文 */
setlocale(LC_ALL, "zh-CN");
wchar_t wch[10] = L"中国人民解放军!";
/* 一字汉字占二个字节,自己实现的求长度,系统自带的函数为:wcslen() */
int length = mywcslen(wch);
printf("%d\n", length);
wprintf(L"%ls", wch);
system("pause");
}