如何以编程方式正确设置 JVM (1.5.x) 使用的默认字符编码?
我读过 -Dfile.encoding=whatever
曾经是旧 JVM 的方式。由于我不会进入的原因,我没有那种奢侈。
我努力了:
System.setProperty("file.encoding", "UTF-8");
并且属性已设置,但它似乎不会导致最终的 getBytes
下面调用使用 UTF8:
System.setProperty("file.encoding", "UTF-8");
byte inbytes[] = new byte[1024];
FileInputStream fis = new FileInputStream("response.txt");
fis.read(inbytes);
FileOutputStream fos = new FileOutputStream("response-2.txt");
String in = new String(inbytes, "UTF8");
fos.write(in.getBytes());
原文由 Scott T 发布,翻译遵循 CC BY-SA 4.0 许可协议
不幸的是,必须在 JVM 启动时指定
file.encoding
属性;当您输入主要方法时,String.getBytes()
使用的字符编码以及InputStreamReader
和OutputStreamWriter
-d 的默认构造函数已永久缓存正如 Edward Grech 指出的那样, 在这种特殊情况下,环境变量
JAVA_TOOL_OPTIONS
可 用于指定此属性,但通常是这样完成的:Charset.defaultCharset()
将反映对file.encoding
属性的更改,但大多数需要确定默认字符编码的核心Java 库中的代码不使用此机制。在编码或解码时,可以查询
file.encoding
属性或Charset.defaultCharset()
找到当前的默认编码,并使用适当的方法或构造函数重载来指定它。