直接上代码,方便同学可以复制下来跑跑
try {
String str = "上海上海";
String gb2312 = new String(str.getBytes("utf-8"), "gb2312");
String utf8 = new String(gb2312.getBytes("gb2312"), "utf-8");
System.out.println(str.equals(utf8));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
结果打印false
jdk7和8下面都是这结果,ide编码是utf-8
跪请大神赐教啊!!!!
2 回答
www说
TA贡献1775条经验 获得超8个赞
Java 所有的 String 都是 Unicode 编码的,使用 String.getBytes(...) 获得的就是对于编码的字节数组,你这段代码效果是把 UTF8 编码的字节数组直接读成 GB2312 的,当然是不对的。
String 本身就是统一的编码了,如果需要输出特定编码的字符串,直接使用 String.getBytes(...) 就能获得对应编码的字符串字节数组,不存在转换这个概念。
如果是把 UTF8 形式的字符串字节数组,转成 GB2312 形式的,代码应该是
byte[] bytes = ...
String str = new String(bytes, "UTF-8");
bytes = str.getBytes("GB2312");
暮色呼如
TA贡献1853条经验 获得超9个赞
字符串gb2312和utf8都已经是乱码了,new String(str.getBytes("utf-8"), "gb2312")意思是使用utf-8来编码,再使用gb2312来解码,肯定乱码
添加回答
举报
0/150
提交
取消