当前位置: 代码迷 >> J2SE >> 数组变换为什么出错
  详细解决方案

数组变换为什么出错

热度:72   发布时间:2016-04-23 21:17:42.0
求助:数组变换为什么出错?
本帖最后由 proof1 于 2013-12-22 21:01:20 编辑

期望:字节数组A   →  字串C   →  字节数组B
   为何A、B不相同?什么原因?

public class Test {
       public static void main(String args[]) {
             byte[] A={13,-76,-32,125,-22,1,6,-3,9};
             for (int i=0; i<A.length;i++) { System.out.print(A[i]+"    "); }

             String C=new String(A);
             System.out.println("\n"+C);

             byte[] B= C.getBytes();
             for (int i=0; i<B.length;i++) { System.out.print(B[i]+"    "); }
       }
}

------解决方案--------------------
你在用字节数组构造String和从String获得字节数组的时候都应该指定编码方式
package anyPackage;

import java.io.UnsupportedEncodingException;

public class Test {
public static void main(String args[]) {
byte[] A = { 13, -76, -32, 125, -22, 1, 6, -3, 9 };
for (int i = 0; i < A.length; i++) {
System.out.print(A[i] + "    ");
}

String C;
try {
C = new String(A,"IBM273");

System.out.println("\n" + C);

byte[] B;
B = C.getBytes(new String("IBM273"));

for (int i = 0; i < B.length; i++) {
System.out.print(B[i] + "    ");
}
} catch (UnsupportedEncodingException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
}

------解决方案--------------------
我的平台编码默认是用UTF-8
对于byte[] A={13,-76,-32,125,-22,1,6,-3,9};
编码成String后打印??}??
再解码成byte[]数组后是{13,-17,-65,-67,-17,-65,-67,125,-17,-65,-67,1,6,,-17,-65,-67}

参考ASCII表,13是回车
-76和-32都不符合UTF-8的编码后的标准字符流,因此无法识别,给出一个?乱码
125识别为右括号}
后面-22和-3也是无法识别,又来了两个?乱码
1,6,9都是ASCII字符,但不是可打印的,所以没有输出。
最后结果就是??}??(其实13,1,6都还在,只是没法显示)

但是再解码成byte[]数组的时候,?就按照UTF-8标准翻译成了三个字符,但是byte接受不了超过127的数,所以变成了统一的-17,-65,-67。

大致可能就是这个过程吧,但是我也没弄明白为什么13,1,6都在,解码后的9找不到了
------解决方案--------------------
如果没有具体需要,一般来说,对Java的这种理解不合适。Java没有打算让使用者在字节数据和字符数据间随意转换。字符数据是有编码的。字节数据是没有事务意义的二进制数据。例如在你的这个问题中,A应该是字符数据,C是字节数据,B是字符数据。Java语言有很强的事务性,这与c++是不同的。
  相关解决方案