(一)JVM默认字符集——Charset.defaultCharset()

获取Java虚拟机默认字符集,该字符集默认跟操作系统字符集一致,也可以通过-Dfile.encoding="GBK" 来手动设定,但是在程序中通过setProperty方法直接设置并不能改变该方法的返回值。查看或修改操作系统默认字符集请参考下面2篇文章。

查看windows 系统字符集

如何查看和修改操作系统字符集

Java中,字符字节转换时,如果不提供字符集,使用默认字符集。例如,字符串和字节数组转换时,字节流和字符流转换时等。

 String str = "中文";
// 获取JVM默认字符集
System.out.println("defaultCharset:" + Charset.defaultCharset()); System.out.println("##字符串转换成byte数组");
byte[] defaultByteArray = str.getBytes();
byte[] gbkByteArray = str.getBytes("GBK");
byte[] utfByteArray = str.getBytes("UTF-8");
System.out.println("defaultByteArray:"
+ Arrays.toString(defaultByteArray));
System.out.println("gbkByteArray:" + Arrays.toString(gbkByteArray));
System.out.println("utfByteArray:" + Arrays.toString(utfByteArray)); System.out.println("##byte数组转换成字符串");
String defaultStr = new String(defaultByteArray);
String gbkStr = new String(defaultByteArray, "GBK");
String utfStr = new String(defaultByteArray, "UTF-8");
System.out.println("defaultStr:" + defaultStr);
System.out.println("gbkStr:" + gbkStr);
// 因为utf-8是变长编码,没有跟[-42, -48, -50, -60]对应的用utf-8字符集的字符串,所以会乱码
System.out.println("utfStr:" + utfStr); System.out.println("##字节流转化成字符流");
// 文件中只有“中文”2个字,文件采用“GBK”编码,共4个byte
BufferedReader defaultReader = new BufferedReader(
new InputStreamReader(new FileInputStream("src/encode.txt")));
BufferedReader gbkReader = new BufferedReader(new InputStreamReader(
new FileInputStream("src/encode.txt"), "GBK"));
BufferedReader utfReader = new BufferedReader(new InputStreamReader(
new FileInputStream("src/encode.txt"), "UTF-8"));
System.out.println("defaultReader:" + defaultReader.readLine());
System.out.println("gbkReader:" + gbkReader.readLine());
System.out.println("utfReader:" + utfReader.readLine()); System.out.println("##字符流转化成字节流");
BufferedWriter defaultWriter = new BufferedWriter(
new OutputStreamWriter(System.out));
BufferedWriter gbkWriter = new BufferedWriter(new OutputStreamWriter(
System.out, "GBK"));
BufferedWriter utfWriter = new BufferedWriter(new OutputStreamWriter(
System.out, "UTF-8"));
System.out.print("defaultWriter:");
defaultWriter.write(str);
// 这里不能用close()方法,否则System.out也被关闭,后续无输出
defaultWriter.flush();
System.out.print("\r\ngbkReader:");
gbkWriter.write(str);
gbkWriter.flush();
System.out.print("\r\nutfReader:");
utfWriter.write(str);
utfWriter.flush();

Java

defaultCharset:GBK
##字符串转换成byte数组
defaultByteArray:[-42, -48, -50, -60]
gbkByteArray:[-42, -48, -50, -60]
utfByteArray:[-28, -72, -83, -26, -106, -121]
##byte数组转换成字符串
defaultStr:中文
gbkStr:中文
utfStr:????
##字节流转化成字符流
defaultReader:中文
gbkReader:中文
utfReader:????
##字符流转化成字节流
defaultWriter:中文
gbkReader:中文
utfReader:涓枃

(二)Java程序入口文件(main函数所在文件)编码——System.getProperty("file.encoding")

该编码默认值取决于Java程序入口文件(main函数所在文件)编码的编码方式,具体请参考下面文章,也可以在运行Java程序时通过-Dfile.encoding="GBK" 来设定,如果-Dfile.encoding指定的编码方式跟Java程序入口文件的字符集不一致,将会导致乱码。也可以在程序中通过setProperty方法直接设置,这种设置虽然改变了“file.encoding”的值,但是似乎没什么用。

java 中关于System property 之 file.encoding

 System.out.println("##文件编码是GBK,-Dfile.encoding=\"GBK\"");
System.out.println("file.encoding:"
+ System.getProperty("file.encoding"));
// 在不存在的目录下创建文件,查看报错信息
try {
new File("directory/test.txt").createNewFile();
} catch (IOException e) {
e.printStackTrace();
} // ##文件编码是GBK,-Dfile.encoding="UTF-8"
System.out.println("##文件编码是GBK,-Dfile.encoding=\"UTF-8\"");
System.out.println("file.encoding:"
+ System.getProperty("file.encoding"));
// 在不存在的目录下创建文件,查看报错信息
try {
new File("directory/test.txt").createNewFile();
} catch (IOException e) {
e.printStackTrace();
}

Java

##文件编码是GBK,-Dfile.encoding="GBK"
file.encoding:GBK
java.io.IOException: 系统找不到指定的路径。
 at java.io.WinNTFileSystem.createFileExclusively(Native Method)
 at java.io.File.createNewFile(File.java:883)
 at Encoding.main(Encoding.java:72)

##鏂囦欢缂栫爜鏄疓BK,-Dfile.encoding="UTF-8"
file.encoding:UTF-8
java.io.IOException: 绯荤粺鎵句笉鍒版寚瀹氱殑璺緞銆?
 at java.io.WinNTFileSystem.createFileExclusively(Native Method)
 at java.io.File.createNewFile(File.java:883)
 at Encoding.main(Encoding.java:83)

(三)文件名字编码——System.getProperty("sun.jnu.encoding")

有关这个的说明较少,未作深入研究,请参考下面两篇文章。

Java Platform Encoding

Java 的系统属性 sun.jnu.encoding 和 file.encoding 的区别

编码总结一:Java默认字符集的更多相关文章

  1. Linux下修改默认字符集--->解决Linux下Java程序种中文文件夹file.isDirectory()判断失败的问题

    一.问题描述: 一个项目中为了生成树状目录,调用了file.listFiles()方法,然后利用file.isDirectory()方法判断是否为目录,该程序在windows下运行无问题,在Linux ...

  2. Java虚拟机(JVM)默认字符集详解

    Java中对字符串等进行转换字节数组时, 需要根据字符集编码来进行转换, 当不显示的指定字符集编码时(如: "测试".getBytes()), 会使用Charset.default ...

  3. 浅谈java使用指定字符集编码,以及常见的字符集

    问题的引入:在InputStreamReader(OutputStreamWriter)的构造方法中,有指定字符集编码,那么什么是字符集?有哪些常用的字符集?怎么用字符集进行编码? 一   什么是字符 ...

  4. Java 18为什么要指定UTF-8为默认字符集

    在Java 18中,将UTF-8指定为标准Java API的默认字符集.有了这一更改,依赖于默认字符集的API将在所有实现.操作系统.区域设置和配置中保持一致. 做这一更改的主要目标: 当Java程序 ...

  5. 修改MySQL默认字符集编码

    好记心不如烂笔头,很多东西当时没记下来,过了就忘了,下次用到时又得浪费好多时间才能解决.今天又遇到修改MySQL默认字符集编码的问题,折腾了半天解决了,赶快记录下来,以后就不用每次折腾了. 查看MyS ...

  6. java编码原理,java编码和解码问题

    java的编码方式原理 java的JVM的缺省编码方式由系统的“本地语言环境”设置确定,和操作系统的类型无关 . 在JAVA源文件-->JAVAC-->Class-->Java--& ...

  7. 【JAVA编码专题】 JAVA字符编码系列三:Java应用中的编码问题

    这两天抽时间又总结/整理了一下各种编码的实际编码方式,和在Java应用中的使用情况,在这里记录下来以便日后参考. 为了构成一个完整的对文字编码的认识和深入把握,以便处理在Java开发过程中遇到的各种问 ...

  8. JAVA字符编码三:Java应用中的编码问题

    第三篇:JAVA字符编码系列三:Java应用中的编码问题 这部分采用重用机制,引用一篇文章来完整本部分目标. 来源:  Eceel东西在线 问题研究--字符集编码  地址:http://china.e ...

  9. 为 MySQL 设置默认字符集(UTF-8)避免产生乱码

    环境:Windows 7+Wamp Server+MySQL 5.7.9 查看MySQL默认编码: SHOW VARIABLES LIKE 'character%' character_set_cli ...

随机推荐

  1. 如何获得带转义的json内容

    stringify两次 JSON.stringify(JSON.stringify(obj))

  2. ASP.NET Core 基础知识(一) ASP.NET Core是什么?与.NET Framework、Mono之间的关系 ?

    一.概念: ASP.NET Core 是一个开源的.跨平台的 .NET 实现.而 .NET Framework 是基于 Windows 的 .NET 实现,Mono 是 .NET Framework ...

  3. CodeMix使用教程:构建自定义DevStyle主题

    [MyEclipse CI 2019.4.0安装包下载] DevStyle主题允许开发人员自定义工作台,无论是喜欢带有明亮图标的浅色背景还是带有柔和色彩的神色背景,开发人员都可以将工作台调整到适合的色 ...

  4. Django【第25篇】:后端CORS解决跨域问题

    解决跨域问题 一.为什么会有跨域问题? 是因为浏览器的同源策略是对ajax请求进行阻拦了,但是不是所有的请求都给做跨域,像是一般的href属性,a标签什么的都不拦截. 二.解决跨域问题的两种方式 JS ...

  5. 微信小程序开发-入门到熟练(wepy-初级篇)

    Title:最近做完了项目,review代码的同时,就想写一篇详细的小程序开发经历,记录自己的项目从0到1的过程 Desc : 小程序从0到1,从小白到完成项目,你需要这样做: step1: 基础知识 ...

  6. Java 8 Date常用工具类

    原创转载请注明出处:https://www.cnblogs.com/agilestyle/p/11983108.html Demo package org.fool.util; import java ...

  7. CF1242B. 0-1 MST

    题目大意 有一个n个点的完全图,上面有m条边的权值为1,其余为0 求MST n,m<=10^5 题解 方法一: 维护一个点集,表示当前MST中的点 一开始任意加一个点 对于一个未加入的点,如果和 ...

  8. Shell入门02

    Shell入门-02 1.重定向 标准输入(<) 标准输出 标准错误重回定向 程序 = 指令 + 数据 命令   变量 在程序中,数据如何输入?又如何输出? 数据输入:键盘 – 标准输入,但是并 ...

  9. favicon.ico是什么?

    一.什么是favicon? 所谓favicon,便是其可以让浏览器的收藏夹中除显示相应的标题外,还以图标的方式区别不同的网站.favicon 中文名称:网页图标  英文名称:favorites ico ...

  10. ARC模式下delloc()注意事项

    1.ARC模式下delloc()调用触发时机是对象被销毁,如self.属性=nil 2.ARC模式下delloc()里面不需要手动调用[super dealloc]; 因为系统已经自动调用,多此一举的 ...