国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java字符編碼原理(動力節點Java學院整理)

Java字符編碼原理(動力節點Java學院整理)

2020-09-07 08:47Java之家 Java教程

Java開發中,常常會遇到亂碼的問題,一旦遇到這種問題,常常比較煩惱,大家都不想承認是自己的代碼問題,其實搞明白編碼的本質過程就簡單多了,接下來小編給大家帶來java字符編碼原理,要求看看吧

Java開發中,常常會遇到亂碼的問題,一旦遇到這種問題,常常比較煩惱,大家都不愿意承認是自己的代碼有問題。其實編碼問題并沒有那么神秘,那么不可捉摸,搞清Java的編碼本質過程就真相大白了。

先看個圖:

Java字符編碼原理(動力節點Java學院整理)

其實,編碼問題存在兩個方面:JVM之內和JVM之外。

1、Java文件編譯后形成class

這里Java文件的編碼可能有多種多樣,但Java編譯器會自動將這些編碼按照Java文件的編碼格式正確讀取后產生class文件,這里的class文件編碼是Unicode編碼(具體說是UTF-16編碼)。

 因此,在Java代碼中定義一個字符串:

?
1
String s="漢字";

不管在編譯前java文件使用何種編碼,在編譯后成class后,他們都是一樣的----Unicode編碼表示。

2、JVM中的編碼

JVM加載class文件讀取時候使用Unicode編碼方式正確讀取class文件,那么原來定義的String s="漢字";在內存中的表現形式是Unicode編碼。

當調用String.getBytes()的時候,其實已經為亂碼買下了禍根。因為此方法使用平臺默認的字符集來獲取字符串對應的字節數組。在WindowsXP中文版中,使用的默認編碼是GBK,不信運行下:

?
1
2
3
4
5
6
public class Test {
 public static void main(String[] args) {
  System.out.println("當前JRE:" + System.getProperty("java.version"));
  System.out.println("當前JVM的默認字符集:" + Charset.defaultCharset());
 }
}

當前JRE:1.8.0_16

當前JVM的默認字符集:GBK

當不同的系統、數據庫經過多次編碼后,如果對其中的原理不理解,就容易導致亂碼。因此,在一個系統中,有必要對字符串的編碼做一個統一,這個統一模糊點說,就是對外統一。比如方法字符串參數,IO流,在中文系統中,可以統一使用GBK、GB13080、UTF-8、UTF-16等等都可以,只是要選擇有些更大字符集,以保證任何可能用到的字符都可以正常顯示,避免亂碼的問題。(假設對所有的文件都用ASCII碼)那么就無法實現雙向轉換了。

要特別注意的是,UTF-8并非能容納了所有的中文字符集編碼,因此,在特殊情況下,UTF-8轉GB18030可能會出現亂碼,然而一群傻B常常在做中文系統喜歡用UTF-8編碼而不說不出個所以然出來!最傻B的是,一個系統多個人做,源代碼文件有的人用GBK編碼,有人用UTF-8,還有人用GB18030。FK,都是中國人,也不是外包項目,用什么UTF-8啊,神經!源代碼統統都用GBK18030就OK了,免得ANT腳本編譯時候提示不可認的字符編碼

因此,對于中文系統來說,最好選擇GBK或GB18030編碼(其實GBK是GB18030的子集),以便最大限度的避免亂碼現象。

3、內存中字符串的編碼

內存中的字符串不僅僅局限于從class代碼中直接加載而來的字符串,還有一些字符串是從文本文件中讀取的,還有的是通過數據庫讀取的,還有可能是從字節數組構建的,然而他們基本上都不是Unicode編碼的,原因很簡單,存儲優化。 

因此就需要處理各種各樣的編碼問題,在處理之前,必須明確“源”的編碼,然后用指定的編碼方式正確讀取到內存中。如果是一個方法的參數,實際上必須明確該字符串參數的編碼,因為這個參數可能是另外一個日文系統傳遞過來的。當明確了字符串編碼時候,就可以按照要求正確處理字符串,以避免亂碼。

在對字符串進行解碼編碼的時候,應該調用下面的方法:

?
1
2
getBytes(String charsetName)
String(byte[] bytes, String charsetName)

而不要使用那些不帶字符集名稱的方法簽名,通過上面兩個方法,可以對內存中的字符進行重新編碼。

以上所述上小編給大家介紹的java 字符編碼原理,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的,在此也非常感謝大家對服務器之家網站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品亚洲综合 | 激情欧美一区二区免费视频 | 日本a v在线播放 | 超碰伊人网 | 91视频入口| 日韩精品一区二区三区四区五区 | 久久网站热最新地址 | 亚洲电影免费 | 激情婷婷| 中文字幕国产一区 | 日日干夜夜操 | 国产激情视频 | 黄在线看| 中文字幕一区二区三区四区五区 | 国内自拍网站 | 中文字幕不卡 | 亚洲伦理| 久久亚洲一区 | 黄色免费av | 毛片首页| 一二三四区视频在线观看 | 成人国产免费视频 | 欧美日韩亚洲一区 | 99免费在线播放99久久免费 | 在线永久免费观看黄网站 | 亚洲福利电影网 | 成人国产综合 | 国产免费激情视频 | 蜜桃视频一区 | 中文字幕精品一区二区三区精品 | 日韩在线字幕 | 欧美精品一区二区三区四区 | 四虎在线观看 | 国产精品99久久久久久久vr | 精品视频二区三区 | 日韩一区二区精品 | 国产成人影院 | 天天爽夜夜爽夜夜爽精品视频 | 黄桃av| 一呦二呦三呦国产精品 | 欧美精品在线播放 |