unicode? multibyte character?

发表于:2007-05-26来源:作者:点击数: 标签:
宽字符的转换问题 multibyte character 到 wide character 的转换,和unicode有关系吗?本来我以为有,现在看来似乎没有。 我在hp-ux下写的程序表明,将multibyte character 转成 wide character之后,我可以象处理单个英文字符一样来处理单个汉字。但是这个
宽字符的转换问题

  multibyte character 到 wide character 的转换,和unicode有关系吗?本来我以为有,现在看来似乎没有。
  我在hp-ux下写的程序表明,将multibyte character 转成 wide character之后,我可以象处理单个英文字符一样来处理单个汉字。但是这个汉字的编码却仍然是multibyte时的编码。
  虽然这样对于我的处理并没有关系,但是今后如果希望在程序中取得汉字的unicode值,就不知道该怎么做了。

//filename:widechar.cpp
#include<iostream>
#include<fstream>
#include<string>
#include<locale>
namespace std {} using namespace std;
void transline(string &k )
{
 wstring wline;
 wchar_t wcs[512];
 mbstowcs(wcs, k.c_str(),512 );
 wline=wstring(wcs);
 
 cout<<"wide value:"<<hex<<wline[0]<<endl;
 
 return;
}

int main()
{


  string cellpart="┌─┬┐│├┤┼└┴┘";
  setlocale(LC_CTYPE, "");
  int i=0;
  i=cellpart[0];
  cout<<"multibyte value:"<<hex<<i<<endl;
  transline(cellpart);
  return 0;
}
编译命令:
aCC -AA +DD64 widechar.cpp -I/opt/aCC/include_std -lstd_v2 -lCsup_v2 -o
widechar

运行结果:
ipp:/ipp/workbench/c++>./widechar
multibyte value:ffffffa9
wide value:a9b0

原文转自:http://www.ltesting.net