今天遇到一个奇怪的问题,代码如下:
修改代码如下:
如此,结果就出来了,我自己分析下,是因为UnicodeBig是两个字节的,如果是单字节就会转换出错,不知道确切该如何解释!
public static String utfToUni(String str) {
if (str == null) {
return str;
}
try {
byte[] ss = str.getBytes("UTF-8");
str = new String(ss, "UnicodeBig");
} catch (UnsupportedEncodingException e2) {
e2.printStackTrace();
}
return str;
}
public static void main(String... strings) {
System.out.print(Test.utfToUni("h"));
}修改代码如下:
public static String utfToUni(String str) {
if (str == null) {
return str;
}
try {
byte[] ss = str.getBytes("UTF-8");
ss = Test.patch(ss);
str = new String(ss, "UnicodeBig");
} catch (UnsupportedEncodingException e2) {
e2.printStackTrace();
}
return str;
}
/**
* 不足补0
*
* @param b
* @return
*/
public static byte[] patch(byte[] b) {
byte[] ss;
if (b.length % 2 != 0) {
ss = new byte[b.length + 1];
System.arraycopy(b, 0, ss, 0, b.length);
ss[b.length] = 0;
return ss;
}
return b;
}如此,结果就出来了,我自己分析下,是因为UnicodeBig是两个字节的,如果是单字节就会转换出错,不知道确切该如何解释!
本文介绍了一个关于字符串从UTF-8编码转换到UnicodeBig编码时遇到的问题及解决方案。通过调整字节数组长度确保其为偶数,成功避免了单字节字符导致的转换错误。
4092

被折叠的 条评论
为什么被折叠?



