Java项目编码格式的核心是统一使用UTF-8,需在源文件、IDE、编译器(Maven/Gradle)、资源文件、JVM启动参数及日志配置等环节同步设置,形成UTF-8闭环。
Java项目编码格式的核心是统一使用UTF-8,避免中文乱码、编译失败或IDE行为不一致等问题。关键不在“怎么设”,而在“在哪设、设几处、是否同步”。
这是最基础的一环。Java源文件本身需保存为UTF-8(无BOM),否则中文注释或字符串可能被Javac误读。
javac -encoding UTF-8 Main.java
即使源码是UTF-8,编译器默认可能按系统locale解析,Maven/Gradle也需显式声明。
UTF-8 UTF-8
compileJava.options.encoding = "UTF-8"compileTestJava.options.encoding = "UTF-8"
.properties文件默认按ISO-8859-1读取,含中文必须转义(如\u4f60\u597d),但更推荐改用UTF-8格式+配套加载方式。
UTF-8编码,并用ResourceBundle.getBundle(..., new UTF8Control())加载(JDK7+))程序运行时,System.out/printStackTrace可能因终端或JVM默认编码异常显示乱码。
-Dfile.encoding=UTF-8(推荐写入IDE运行配置或shell脚本)locale | grep UTF;Windows CMD可执行chcp 65001
UTF-8 ...
基本上就这些。重点不是每处都设一遍,而是从源码→编译→打包→运行形成UTF-8闭环。多数乱码问题,根源都在某一处漏掉了编码声明。