以GBK 方式编写下面java文件
import java.io.UnsupportedEncodingException;
import java.nio.charset.Charset;
public class EscapeTest {
public static void main(String[] args) throws UnsupportedEncodingException {
String str = "你好";
byte[] b1 = str.getBytes();
String encodedMode = "UTF-8";
System.out.println(new String(b1,encodedMode));
System.out.println(Charset.defaultCharset());
}
}
打开命令行窗口, 执行
javac EscapeTest.java
java EscapeTest
显示内容为
源码中encodedMode 赋值为 "GBK" 后结果为:
这里就可以正常显示.
有这样两个不同结果是因为:
java 编译器将str 的代码点按照utf-16 存入到class 文件. JVM 调用该class 文件后分别以"UTF-8" 和"UTF-16" 进行解码. 来时什么编码, 显示时候还是什么编码, 所以"GBK" 解码是正常.