第一种方式自己实现(笨,但可以知道原理)
/**
* unicode 转中文
* @param str
* @return
*/
public static String ascii2Native(String str) {
StringBuilder sb = new StringBuilder();
int begin = 0;
int index = str.indexOf("\\u");
while (index != -1) {
sb.append(str.substring(begin, index));
sb.append(ascii2Char(str.substring(index, index + 6)));
begin = index + 6;
index = str.indexOf("\\u", begin);
}
sb.append(str.substring(begin));
return sb.toString();
}
/**
* unicode 转字符
* @param str
* @return
*/
private static char ascii2Char(String str) {
if (str.length() != 6) {
throw new IllegalArgumentException( "参数有误!");
}
if (!"\\u".equals(str.substring(0, 2))) {
throw new IllegalArgumentException("参数有误");
}
String tmp = str.substring(2, 4);
int code = Integer.parseInt(tmp, 16) << 8;
tmp = str.substring(4, 6);
code += Integer.parseInt(tmp, 16);
return (char) code;
}
第二种方式(推荐)
org.apache.commons.lang3.StringEscapeUtils.unescapeJava(yourstr) 有现成的就用现成的,效率高
结论:一定要多看源码,多使用现成的工具类。
本文介绍了两种将Unicode编码转换为中文的方法。第一种方法通过手动解析Unicode编码并转换为对应的中文字符,虽然过程繁琐但有助于理解转换原理;第二种方法则推荐使用Apache Commons Lang库中的StringEscapeUtils.unescapeJava()函数,这种方法简单高效。
1079

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



