======================================================
注:本文源代码点此下载
======================================================
故事还在继续....
早上在家里调试过好的,然后email到公司,继续调。却发现原来的程序出错了!
问题在这两行:
strtempunicode = new string(arybyte, 0, 2, "unicode");
byte[] arybyteresult = strtempunicode.getbytes();
得到的arybyteresult长度竟然是0!在家里还是2的。呜~
后来问了公司的同事,原来unicode本身就有两种编码,一种是高位在前,一种是低位在前,java采用的默认unicode编码是根据cpu不同而不同的。家里是intel,默认是用unicode;公司里恰好是amd,默认用iso-10646-ucs-2,所以到公司将上面两行换成下面两行就行了:
strtempunicode = new string(arybyte, 0, 2, "iso-10646-ucs-2");
byte[] arybyteresult = strtempunicode.getbytes();
最后的问题是:我们的程序如何自动适应cpu的不同编码?
1.可以先用unicode试解析,当arybyteresult长度是0时再用iso-10646-ucs-2。我想到的,比较笨。
2.先放一个基准字符串得到byte顺序,根据顺序就知道是用unicode还是iso-10646-ucs-2了
回复 引用 查看
======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/