3671|8

71

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

Unicode的问题,关于char 和TCHAR?? [复制链接]

我在evc定义如下:
               char *s = "北";
               TCHAR *c = "北";
但是我分别读取*s 和*c的值发现是不一样的,*s = -79说明是一个汉字,即读取的是“北”字的前8个字节;
                              但*c = 21271,转换成16进制是5317,感觉这个数字跟“北”字没有任何关系
“北”的机内码16进制是B1B1.
  请大家帮忙看一下,解答一下char跟TCHAR有什么区别吗?谢谢!

最新回复

如果是做wince,那么就不会用到“点阵显示汉字”,如果不是wince,那么可以不用UNICODE。  详情 回复 发表于 2008-5-12 21:04
点赞 关注

回复
举报

82

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
这是wince下的基础课程:UNICODE

建议你找windos 编程里面UNICODE的那一章来看看。
 
 

回复

70

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
上面有一点写错了,*c = _T(“北”)
 
 
 

回复

89

帖子

0

TA的资源

一粒金砂(初级)

4
 
引用 1 楼 yashi 的回复:
这是wince下的基础课程:UNICODE

建议你找windos 编程里面UNICODE的那一章来看看。

我看了哦,没有发现有什么的啊,只是TCHAR比char多占了一个字节,就是说同样对于一个字母如:A,char是0x41,TCHAR则是0x0041哦,
但对于汉字是怎么样的呢,同样如果对于“北”字,那对于char应该是0xB1 0xB1
那么TCHAR既然已经是双字节了,汉字也是双字节存放的,那TCHAR我觉得应该是0xB1B1啊

这些是个人的想法,请指教,谢谢!
 
 
 

回复

84

帖子

0

TA的资源

一粒金砂(初级)

5
 
“北”的UNICODE就是5317,
机内码是在ASCII的基础上扩展的,和UNICODE编码不一样。
 
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

6
 
引用 4 楼 yashi 的回复:
“北”的UNICODE就是5317,
机内码是在ASCII的基础上扩展的,和UNICODE编码不一样。

那请问我如果要用点阵显示汉字的话,是不能用TCHAR类型的了,否则的话读出来的机内码不正确了哦?
 
 
 

回复

69

帖子

0

TA的资源

一粒金砂(初级)

7
 
倒网上去找个映射表,使用的时候查表
 
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

8
 
引用 6 楼 xiaohf702 的回复:
倒网上去找个映射表,使用的时候查表

找到了哦,谢谢提示!
 
 
 

回复

83

帖子

0

TA的资源

一粒金砂(初级)

9
 
如果是做wince,那么就不会用到“点阵显示汉字”,如果不是wince,那么可以不用UNICODE。
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表