【Java】Idea运行JDK1.8,Build时中文内容GBK UTF-8编码报错一堆方块码

问题描述

在Windows系统本地运行一个JDK1.8的项目时,包管理用的Gradle,一就编码报错(所有的中文内容,包括中文注释、中文的String字面量),但程序还是正常运行。具体如下:

解决

1. Idea更改编码方式?

首先参考了网上一些帖子,先试试无脑把Idea所有的Encoding都改成UTF-8:

  1. 文件编码 File Encoding
  2. 控制台 Console

但问题还是没解决,说明这里的编码错误可能不来自IDEA。

后面看到篇文章专门将了IDEA编码问题,这种"口字码"一般就是用UTF-8的方式读取GBK编码文件,而JDK18之前是UTF8编码所以能用UTF8,JDK18之后成了GBK所以用UTF8有乱码。可以通过以下命令查看系统默认字符集:

java 复制代码
System.out.println(Charset.defaultCharset());

我这显示的是GBK,但文件的编码是UTF-8。GBK全称《汉字内码扩展规范》,中文的Windows系统默认的字符集就是GBK,这也是这里编码冲突的主要原因。上面的报错看上去是 Gradle 和 Javac 把项目当成了 GBK 编译了。从命令行直接用 gradle build,也是类似的结果。

2. Gradle指定编码(成功解决)

后来看到个文章,Use UTF-8 everywhere in the IDE,给了个方案在Gradle中指定项目编码格式

java 复制代码
tasks.withType(JavaCompile) {
    options.encoding = 'UTF-8'
}

这样我这就不报错了。

3. 其他方法

  1. 如果项目和运行 Gradle 的环境用的JDK 18 之后的版本,就不会有这种问题。因为JDK18之后可以用GBK编码。
  2. JVM参数在启动的时候设置属性 -Dfile.encoding=UTF-8

不过,我现在这个项目是给其他项目组打包的SDK,人家需要JDK8的版本,并且也不好让人家也设置JVM参数(太麻烦了),所以这两个方法不太适用。

相关推荐
探索java9 分钟前
Java 深入解析:JVM对象创建与内存机制全景图
java·jvm
zhangfeng113310 分钟前
python 数据分析 单细胞测序数据分析 相关的图表,常见于肿瘤免疫微环境、细胞亚群功能研究 ,各图表类型及逻辑关系如下
开发语言·python·数据分析·医学
Sylvia-girl16 分钟前
Java---IDEA
java·开发语言·intellij-idea
Z_W_H_23 分钟前
【Springboot】Bean解释
java·开发语言
Otaku love travel1 小时前
老系统改造增加初始化,自动化数据源配置(tomcat+jsp+springmvc)
java·tomcat·初始化·动态数据源
DKPT1 小时前
Java设计模式之行为型模式(责任链模式)介绍与说明
java·笔记·学习·观察者模式·设计模式
L_autinue_Star2 小时前
手写vector容器:C++模板实战指南(从0到1掌握泛型编程)
java·c语言·开发语言·c++·学习·stl
晨岳2 小时前
CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境
java·redis·mysql·nginx·centos·tomcat
执笔诉情殇〆2 小时前
前后端分离(java) 和 Nginx在服务器上的完整部署方案(redis、minio)
java·服务器·redis·nginx·minio
元气小嘉2 小时前
前端技术小结
开发语言·前端·javascript·vue.js·人工智能