我遇到编码问题。相同的代码在 Android 和 Windows 上产生不同的输出。我无法修改Android应用程序,因此我需要在Windows上找到解决方案。 这是代码:
public void test() throws UnsupportedEncodingException
{
byte[] a = {-95, -10, -63, -74, 99, -10, 74, -56, -85, 105};
String ab = new String(a,"UTF-8");
System.out.println("out:"+Arrays.toString((new StringBuilder(String.valueOf(ab))).toString().getBytes("UTF-8")));
}
输出:
out:[-17, -65, -67, -17, -65, -67, 118, 99, -17, -65, -67, 74, -56, -85, 105] (on Android)
out:[-17, -65, -67, -17, -65, -67, -17, -65, -67, -17, -65, -67, 99, -17, -65, -67, 74, -56, -85, 105] (on Windows)
Android 似乎使用“java.nio.charset.CharsetICU[UTF-8]”。有什么建议吗?
谢谢, 亚历克斯
最佳答案
这是因为 {-95, -10, -63, -74, 99, -10, 74, -56, -85, 105} 不是有效的 UTF-8 字节序列。 new String(bytes, "UTF-8") 在这种情况下不会抛出任何异常,但结果很难预测。阅读 http://en.wikipedia.org/wiki/UTF-8字节序列部分无效。
尝试使用 ISO-8859-1,它将字节转换为字符 1 : 1
关于java - 编码差异 UTF-8 Android 4.2.2 <=> Windows 7,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16240245/