我创建了一个字符串,并使用 EBCDIC 编码转换了一个字节数组。当我打印数组时,H 的值与 EBCDIC 图表中发现的值不同。
预期输出
“H”的 EBCDIC 值 --> 200,根据链接 EBCDIC 1047 chart
实际输出
“H”的 EBCDIC 值-->[-56]
public static void main(String[] args) throws UnsupportedEncodingException {
String str = "H";
byte[] b1 = new byte[10];
b1 = str.getBytes("Cp1047");
System.out.println(Arrays.toString(b1));
for (byte b : b1) {
System.out.println(b);
}
b1 = str.getBytes("UTF-16");
System.out.println(Arrays.toString(b1));
b1 = str.getBytes();
System.out.println(Arrays.toString(b1));
}
最佳答案
在你的循环中
for (byte b : b1)
System.out.println(b);
当 Java 将 b(一个字节)提升为整数时,它会进行符号扩展,从而导致打印 0xFFFFFFC8
的值。 0xFFFFFFC8
是有符号数 -56 的二进制补码表示形式。请参阅this 。您可以通过执行以下操作来阻止符号扩展:
for (byte b :b1)
System.out.println(b & 0xFF);
这将导致打印值0xC8
(十进制为200)。
关于java - 打印包含 EBCDIC 值的字节数组未给出预期值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43100662/