cmd命令列中執行Java檔案中文字元亂碼情況解決
如上所示的錯誤
由於JDK是國際版的,在編譯的時候,如果我們沒有用-encoding引數指定我們的JAVA源程式的編碼格式,則javac.exe首先獲得我們作業系統預設採用的編碼格式,也即在編譯java程式時,若我們不指定源程式檔案的編碼格式,JDK首先獲得作業系統的file.encoding引數(它儲存的就是作業系統預設的編碼格式,如WIN2k,它的值為GBK),然後JDK就把我們的java源程式從file.encoding編碼格式轉化為JAVA內部預設的UNICODE格式放入記憶體中。然後,javac把轉換後的unicode格式的檔案進行編譯成.class類檔案,此時.class檔案是UNICODE編碼的,它暫放在記憶體中,緊接著,JDK將此以UNICODE編碼的編譯後的class檔案儲存到我們的作業系統中形成我們見到的.class檔案。對我們來說,我們最終獲得的.class檔案是內容以UNICODE編碼格式儲存的類檔案,它內部包含我們源程式中的中文字串,只不過此時它己經由file.encoding格式轉化為UNICODE格式了。當我們不加設定就編譯時,相當於使用了引數:javac
-encoding gbk XX.java,當然就會出現不相容的情況。
解決:是編碼問題
1、轉換成UTF-8編碼格式,但仍然有錯
解決辦法是:應該使用-encoding引數指明編碼方式:javac -encoding UTF-8 XX.java
2、開始-->計算機-->滑鼠反鍵(滑鼠右鍵)-->屬性-->高階系統設定-->環境變數-->系統變數
新建。然後輸入:“JAVA_TOOL_OPTIONS”變數,值為“-Dfile.encoding=UTF-8”
然後確定、確定、在確定後。新開命令列視窗,再次輸入javac命令。
3、若編寫程式碼時使用的是notepad++,先將其編碼格式換成ANSI,再寫入漢字。此時執行javac -d . XX.java就正確了。