wchar_t是C/C++的字符类型,是一种扩展的存储方式

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 <iostream>
#include <locale>
#include <cstdlib>
 
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<<wStr<<endl;
     getchar (); getchar ();
     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;
}
参考资料
  • 1.  GNU Libc:Introduction to Extended Characters 


参考:

wchar 数据类型  谷歌


你可能感兴趣的:(wchar_t是C/C++的字符类型,是一种扩展的存储方式)