如何判断某两个字节和在一起是不是一个有效的双字节中文字符?

liwzh 2002-03-08 10:56:30
如何判断某两个字节和在一起是不是一个有效的双字节中文字符?
...全文
105 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
ma811 2002-03-08
  • 打赏
  • 举报
回复
IsCharAlpha
liwzh 2002-03-08
  • 打赏
  • 举报
回复
确切的说,我想做出自动换行效果,但不想将一个双字节字符分开。
wuxq 2002-03-08
  • 打赏
  • 举报
回复
dos下
第一字节>=0xb0,第二字节>=0xa1
windows下
第一字节>=0x81,第二字节>=0x40
你可以查一下字符映射表。
apple_1976 2002-03-08
  • 打赏
  • 举报
回复

我感觉最简单的方法可以用MessageBox显示一下两个字节构成的字符串。

还可以用MultiBytetoWideChar函数来识别,公供参考!

iamjx1234 2002-03-08
  • 打赏
  • 举报
回复
是第一个字节应该大于某一十六进制值,值为多少我忘了,你查一下吧!
liwzh 2002-03-08
  • 打赏
  • 举报
回复
判断是不是双字节很容易,但判断是不是双字节的头一个字节很难,因为不知道应取哪两个字节来判断,我看还是从口头开始算起。算最后一个字节是不是双字节字符的头一个字符。例:
bool IsLeadChar(char *buf,int strnum)
{
int num = 0;
for(int i = 0;i < strnum;i ++)
{
if(BYTE(*buf) >= 0x40)
{
if((num % 2) == 0)
{
if(BYTE(*buf) >= 0x81)
num ++;
else
num = 0;
}
else
num ++;
}
else
num = 0;
buf ++;
}
if((num % 2) == 1)
return true;
else
return false;
}
eion 2002-03-08
  • 打赏
  • 举报
回复
如果两个字节的最高位都是 1,一般的就是双字节的字

char s[]=................;
if( s[i]&0x80 && s[i+1]&0x80 ) i+=2;//是双字
else i++;
prometheusphinx 2002-03-08
  • 打赏
  • 举报
回复
IsDBCSLeadByte
IsDBCSLeadByteEx

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧