关于C语言的中文字符串
(2011-05-27 11:31:27)
标签:
中文字符串 |
分类: 编程语言园地 |
首先中文编码是4个字节,相当于四个字符。
所以你要放的话,可以这样。
char a[] = {"你好"};
printf("%s",a);
还可以以下方式存放:
char a[]="张三";
char b[]="李四";
中文数组一般是Unicode编码
#include "stdafx.h"
#include <iostream>
#include <string>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
string ss1[2];
ss1[0] = "张三";
ss1[1] = "李四";
cout<<ss1[0]<<endl;
return 0;
}
-------------------------------------------------------------------------------------------
wchar_t是C/C++的字符数据类型,就是unicode编码,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宽字符类型的相关操作。
#include <iostream>
#include <stdlib>
using namespace std;
void main()
{
locale loc( "chs" );//定义“区域设置”为中文方式
wcout.imbue( loc );//载入中文字符输入方式
wchar_t str[]=L"中国";//定义宽字符数组,注意L是大写
wcout<<str<<endl;//显示宽字符数组,下同
wprintf(str);
system("pause");
}
-----------------------------------------------------------------------------------------
wchar_t数据类型一般为16位或32位,但不同的C或C++库有不同的规定,如GNU Libc规定wchar_t为32位[1],总之,wchar_t所能表示的字符数远超char型。
标准C++中的wprintf()函数以及iostream类库中的类和对象能提供wchar_t宽字符类型的相关操作。 #include <iostream>
#include <stdlib>
using namespace std;
void main()
{
locale loc( "chs" );//定义“区域设置”为中文方式
wcout.imbue( loc );//载入中文字符输入方式
wchar_t str[]=L"中国";//定义宽字符数组,注意L是大写
wcout<<str<<endl;//显示宽字符数组,下同
wprintf(str);
system("pause");
}
------------------------------------------------------------------------------------------
UNICODE
作者:NorthTibet
简介
UNICODE到底是什么?
Visual
字符串
象下面这样声明函数原形:
为了将上面的声明改成支持双字节的
或者
注意这里的
在代码中,凡是用关键字
TEXT