Unicode 转换成 Ascii (把Unicode 中文字符串输入到文本中)

之前一直用Unicode编码,将英文字符串输入到文本中不会出现乱码,但当把Unicode形式的中文字符串输入到文本中则会出现乱码现象。

注意:文本文件是以 Ascii 格式保存数据的

   Unicode 规定一个字符占两个字节

比如:unicode编码:this is a test

其16进制为:FF FE 74 00 68 00 69 00  73 00 20 00 69 00 73 00 20 00 61 00 20 00 74 00  65 00 73 00 74 00 

以下代码 是将Unicode 转换成 Ascii 不会出现乱码。

char* ch;
CString m_AllInfo("这是一个小小的测试!!");
	int length=WideCharToMultiByte(CP_ACP,0,m_AllInfo,-1,NULL,0,NULL,FALSE);
	ch=new char[length+1];
	WideCharToMultiByte(CP_ACP,0,m_AllInfo,-1,ch,length,NULL,FALSE);
输出到文本文件中要注意 字符ch的长度。

这样把 ch 输入到文本文件中就不会出现乱码了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值