昨天有個剛學java的師弟發了個程序給我,說死活編譯不過,老是報編碼問題,自己試了一下,也出問題了...
當我們編輯了一個Java源文件保存時,是以操作系統默認的字符編碼保存的(Windows xp默認字符集是GBK)。當調用javac命令時,會把源文件進行一次編碼轉換,如果沒有指定字符集,就從操作系統默認的字符集轉換成Java內部默認的unicode字符集,然後再將源文件編譯成class文件,並且以unicode的編碼形式保存到硬盤上。
仔細查看了一下錯誤,才發現是文件編碼的問題,他的文件用的是UTF-8編碼的,於是加了-encoding編譯成功~~
public class Test { public static void main(String[] args) { System.out.println("你好!"); }}D:/>javac Test.java
Test.java:3: 警告:編碼GBK 的不可映射字符System.out.println("浣ソ錛?); ^Test.java:3: 未結束的字符串字面值System.out.println("浣ソ錛?); ^Test.java:3: 需要';' System.out.println("浣ソ錛?); ^Test.java:5: 進行語法解析時已到達文件結尾}D:/>javac -encoding utf-8 Test.java
jdk在編譯的時候,如果沒有用-encoding參數指定java源程序的編碼格式,則javac首先獲得操作系統默認採用的編碼格式,也即在編譯java程序時,若不指定源程序文件的編碼格式,jdk首先獲得操作系統默認的編碼格式,xp是GBK,然後jdk就把java源程序從該編碼格式轉化為java內部默認的unicode格式放入內存中。然後,javac把轉換後的unicode格式的文件進行編譯成.class類文件,此時.class文件是unicode編碼的,它暫放在內存中,緊接著,jdk將此以unicode編碼的編譯後的class文件保存到操作系統中形成.class文件。最終獲得的.class文件是內容以unicode編碼格式保存的類文件,它內部包含源程序中的中文字符串,只不過此時它己經由安裝系統編碼格式轉化為unicode格式了。
一般我比較喜歡用UTF-8的,在windows和linux下都能正常跑...
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。