默然说话

一个异想天开的人做着异想天开的梦

牟勇ID:mouyong
64387次访问,排名1577好友4人,关注者6
我快乐,我存在
mouyong的文章
原创 108 篇
翻译 4 篇
转载 30 篇
评论 12 篇
默然的公告
如果要联系我,希望能说明来意,谢谢.

点击这里给我发消息

Google

最近评论
peigen:又~~~~为什么是又呢???
dcopperfield:顶下
gaoyunpeng:无意中进入到这个博客,很快就被里面的内容所吸引,感觉很有意思,不知道为什么会有这样的感觉,或许只是一种直觉上的吸引吧,一直在看博客里的文章,觉得很不错,天天等更新,哈哈,终于看到新的文章啦~
我会一直关注的~
mouyong:谢谢你的鼓励,我会更加努力。
了祝愿你实现自己的理想,达成自己的目标
wsspy007:牟老师,我发现你是我见过最好的老师了,为学生考虑最多,一切为学生着想,不知道牟老师还记得我么,张伟(无名小辈肯定你是忘记了),第一期跟杨大宇他们在一个班的,补考两次都没有及格,我现在不在昆明了,在胜利油田,这里一切都很好,一个月的薪金能顶得上昆明3-5个月的薪水,但是我不喜欢这份工作,钱固然多,但是从学校出来步入社会以后才发现,我还是应该走软件开发这条路,现在每天我只睡4-6个小时,工作12……
文章分类
收藏
    相册
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    转载 一个关于UTF-8的问题收藏

    新一篇: 不带变量的表达式解析器(源码) | 旧一篇: 成为游戏制作者,你准备好了么?

    这个问题应该是由UTF-8编码的特点造成的。
    UTF-8是一种变长字节编码方式。对于某一个字符的UTF-8编码,如果只有一个字节则其最高二进制位为0;如果是多字节,其第一个字节从最高位开始,连续的二进制位值为1的个数决定了其编码的位数,其余各字节均以10开头。UTF-8最多可用到6个字节。
    如表:
    1字节 0xxxxxxx
    2字节 110xxxxx 10xxxxxx
    3字节 1110xxxx 10xxxxxx 10xxxxxx
    4字节 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
    5字节 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
    6字节 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
    因此UTF-8中可以用来表示字符编码的实际位数最多有31位,即上表中x所表示的位。除去那些控制位(每字节开头的10等),这些x表示的位与UNICODE编码是一一对应的,位高低顺序也相同。
    实际将UNICODE转换为UTF-8编码时应先去除高位0,然后根据所剩编码的位数决定所需最小的UTF-8编码位数。
    因此那些基本ASCII字符集中的字符(UNICODE兼容ASCII)只需要一个字节的UTF-8编码(7个二进制位)便可以表示。

    对于上面的问题,代码中给出的两个字节是
    十六进制:C0 B1
    二进制:11000000 10110001
    对比两个字节编码的表示方式:
    110xxxxx 10xxxxxx
    提取出对应的UNICODE编码:
    00000 110001
    可以看出此编码并非“标准”的UTF-8编码,因为其第一个字节的“有效编码”全为0,去除高位0后的编码仅有6位。由前面所述,此字符仅用一个字节的UTF-8编码表示就够了。
    JAVA在把字符还原为UTF-8编码时,是按照“标准”的方式处理的,因此我们得到的是仅有1个字节的编码。

    大家可以试试运行这段代码:
    public class TestUTF8 {
    public static void main(String[] args) throws Exception {
    byte[][] bytes = {
    // 00110001
    {(byte)0x31},
    // 11000000 10110001
    {(byte)0xC0,(byte)0xB1},
    // 11100000 10000000 10110001
    {(byte)0xE0,(byte)0x80,(byte)0xB1},
    // 11110000 10000000 10000000 10110001
    {(byte)0xF0,(byte)0x80,(byte)0x80,(byte)0xB1},
    // 11111000 10000000 10000000 10000000 10110001
    {(byte)0xF8,(byte)0x80,(byte)0x80,(byte)0x80,(byte)0xB1},
    // 11111100 10000000 10000000 10000000 10000000 10110001
    {(byte)0xFC,(byte)0x80,(byte)0x80,(byte)0x80,(byte)0x80,(byte)0xB1},
    };
    for (int i = 0; i < 6; i++) {
    String str = new String(bytes[i], "UTF-8");
    System.out.println("原数组长度:" + bytes[i].length +
    "\t转换为字符串:" + str +
    "\t转回后数组长度:" + str.getBytes("UTF-8").length);
    }
    }
    }
    运行结果为:
    原数组长度:1 转换为字符串:1 转回后数组长度:1
    原数组长度:2 转换为字符串:1 转回后数组长度:1
    原数组长度:3 转换为字符串:1 转回后数组长度:1
    原数组长度:4 转换为字符串:1 转回后数组长度:1
    原数组长度:5 转换为字符串:1 转回后数组长度:1
    原数组长度:6 转换为字符串:1 转回后数组长度:1 

     

    发表于 @ 2006年08月24日 19:15:00|评论(loading...)|编辑

    新一篇: 不带变量的表达式解析器(源码) | 旧一篇: 成为游戏制作者,你准备好了么?

    评论:没有评论。

    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © 默然