亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

java utf8 轉 gb2312 錯誤?

java utf8 轉 gb2312 錯誤?

慕碼人8056858 2019-02-20 02:54:10
直接上代碼,方便同學可以復制下來跑跑 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");
查看完整回答
反對 回復 2019-03-01
?
暮色呼如

TA貢獻1853條經驗 獲得超9個贊

字符串gb2312和utf8都已經是亂碼了,new String(str.getBytes("utf-8"), "gb2312")意思是使用utf-8來編碼,再使用gb2312來解碼,肯定亂碼

查看完整回答
反對 回復 2019-03-01
  • 2 回答
  • 0 關注
  • 788 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號