Chinaunix首页 | 论坛 | 博客
  • 博客访问: 413115
  • 博文数量: 116
  • 博客积分: 7087
  • 博客等级: 少将
  • 技术积分: 1175
  • 用 户 组: 普通用户
  • 注册时间: 2005-02-19 23:32
文章分类

全部博文(116)

文章存档

2012年(1)

2011年(2)

2010年(10)

2009年(21)

2008年(18)

2007年(12)

2006年(21)

2005年(31)

我的朋友

分类:

2005-04-11 10:21:06

宽字符的转换问题

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

//filename:widechar.cpp
#include
#include
#include
#include
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:"< 
 return;
}

int main()
{


  string cellpart="┌─┬┐│├┤┼└┴┘";
  setlocale(LC_CTYPE, "");
  int i=0;
  i=cellpart[0];
  cout<<"multibyte value:"<  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

阅读(1634) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~