OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4160|回复: 1

关于汉字内码与字库对应,以及ff_convert函数的一点疑问?

[复制链接]

6

主题

23

帖子

0

精华

初级会员

Rank: 2

积分
55
金钱
55
注册时间
2016-4-23
在线时间
15 小时
发表于 2016-5-17 14:14:10 | 显示全部楼层 |阅读模式
5金钱
按照GBK编码规则,每个内码由2个字节组成,第一字节从0X81~0XFE,第二个字节从(0X40~0XFE)-1,一共能代表23940个汉字可是为什么在cc936文件中的大数组一共有  
for(i=0;;i++)
   {
    if(!uni2oem)
       break;
   }
   printf("\r\ncount of uni2oem=%d",i+2);  ====一共43586个值????他们是怎么对应起来的;

也因此关于ff_convert()函数中的二分法就不太理解了,sizeof(uni2oem or oem2uni)=87172,是数组个数的两倍能对应起来,hi = sizeof uni2oem / 4 - 1=;这里就不太理解(原子哥以前回答的一个帖子是

4个字节表示一个组。
UNICODE占2字节,GBK占2字节,一组就是4字节。
16,表示最多进行16次二分,你可以算算2的16次方可以表示多大的表。

没太明白,因此  hi = sizeof oem2uni / 4 - 1,然后li=0;i = li + (hi - li) / 2;不就是在0到二分之数组大小之间用二分法,而对于另一部分就没有进行对比了呀?
求助各位,这里是我哪里理解错了?

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-5-18 21:22:37 | 显示全部楼层
自己模拟吧。搞个小点的工程,比如整个大小为1024,然后自己去软件仿真分析下就明白了。
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-27 08:23

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表