wchar_t是C/C++的字符类型,是一种扩展的存储方式,wchar_t类型主要用在国际化程序的实现中,但它不等同于uni编码。uni编码的字符一般以wchar_t类型存储。
外文名
wchar_t
属 于
C/C++的字符类型
类 别
一种扩展的存储方式
概 念
8位字符类型
目录
1简介
2例如
3将char转换成wchar_t
1简介
char是8位字符类型,最多只能包含256种字符,许多外文字符集所含的字符数目超过256个,char型无法表示。
wchar_t数据类型一般为16位或32位,但不同的C或C++库有不同的规定,如GNU Libc规定wchar_t为32位[1] ,总之,wchar_t所能表示的字符数远超char型。
标准C++中的wprintf()函数以及iostream类库中的类和对象能提供wchar_t宽字符类型的相关操作。
2例如
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include
#include
#include
usingnamespace std;
locale loc("chs");//windows下ok
//这段貌似在ubuntu下ok
//locale loc("zh_CN.UTF-8");
//而且还需要在ubuntu的终端中执行:
//sudo locale-gen
int main(){
wchar_t wStr[]=L"这是一段中文";
wcout.imbue(loc);
wcout<
return0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
package MyJava;
//下面是一段demo其它请参考相关文档
public class MyDemo{
public static void main(Stringargs[]){
intnum = 300;
System.out.println("编号:"+num);
inta = 30;
intb = 20;
intc = a+b;
System.out.println("a+b="+c);
}
}
3将char转换成wchar_t
可以用TEXT()方法将char转换成wchar_t
例如: wchar_t appName[5]=TEXT("test");
方法2:
1
2
3
4
5
6
7
8
wchar_t* c2w(const char *str)
{
int length = strlen(str)+1;
wchar_t *t = (wchar_t*)malloc(sizeof(wchar_t)*length);
memset(t,0,length*sizeof(wchar_t));
MultiByteToWideChar(CP_ACP,0,str,strlen(str),t,length);
return t;
}