我正在尝试使用Java文件从数据库中检索一些UTF-8单编码中文字符。当我这样做时,字符将作为问号返回。
但是,当我显示数据库中的字符时(使用select * from ...
),字符会正常显示。当我在包含中文字符的Java文件中打印字符串时,它们也会正常打印。
我在Eclipse中遇到了这个问题:当我运行程序时,字符被打印为问号。但是当我以UTF-8格式保存Java文件时,这个问题就解决了。
终端中运行“locale”当前返回:
LANG="en_GB.UTF-8"
LC_COLLATE="en_GB.UTF-8"
LC_CTYPE="en_GB.UTF-8"
LC_MESSAGES="en_GB.UTF-8"
LC_MONETARY="en_GB.UTF-8"
LC_NUMERIC="en_GB.UTF-8"
LC_TIME="en_GB.UTF-8"
LC_ALL=
我还尝试使用以下方法编译我的java文件:
javac -encoding UTF-8 [java file]
但是,输出仍然是问号。
它有时只会显示字符,这很奇怪。有没有人对此有解释?或者甚至更好,如何解决这个问题,以便正确显示字符?
答案 0 :(得分:4)
System.out
打印流不是作为UTF-8打印流创建的。你可以把它转换成这样的:
import java.io.PrintStream;
import java.io.UnsupportedEncodingException;
public class JavaTest {
public static void main(String[] args) {
try{
PrintStream out = new PrintStream(System.out, true, "UTF-8");
out.println("Hello");
out.println("施华洛世奇");
out.println("World");
}
catch(UnsupportedEncodingException UEE){
//Yada yada yada
}
}
}
你也可以set the default encoding as per here通过:
java -Dfile.encoding=UTF-8 -jar JavaTest.jar