首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 其他相关 >

空utf8文件占三字节的有关问题

2012-11-09 
空utf8文件占三字节的问题???? 本来只是想试试是不是基本所有汉字在utf8中都占三字节,于是Windows下建了了

空utf8文件占三字节的问题

???? 本来只是想试试是不是基本所有汉字在utf8中都占三字节,于是Windows下建了了一空文件,写了一汉字,代码:

FileInputStream fis = new FileInputStream("C://test.txt");byte[] test = new byte[1024];int length = fis.read(test);

?
???? 诡异的事情发生了,居然length是6!郁闷,查了一下:
?写道“Unicode规范中有一个BOM的概念。BOM——Byte Order Mark,就是字节序标记。在这里找到一段关于BOM的说明:
引用:
在UCS 编码中有一个叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的编码是FEFF。而FFFE在UCS中是不存在的字符,所以不应该出现在实际传输中。UCS规范建议我们在传输字节流前,先传输字符"ZERO WIDTH NO-BREAK SPACE"。这样如果接收者收到FEFF,就表明这个字节流是Big-Endian的;如果收到FFFE,就表明这个字节流是Little- Endian的。因此字符"ZERO WIDTH NO-BREAK SPACE"又被称作BOM。
UTF-8编码的文件中,BOM占三个字节。”?
值应该是FFFE。
????? 第一次写博客,好吧,就这样吧...

?

热点排行