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