【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参数(太麻烦了),所以这两个方法不太适用。

相关推荐
plainGeekDev1 小时前
ButterKnife → ViewBinding
android·java·kotlin
像我这样帅的人丶你还17 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩17 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia18 小时前
Mybatis的日志输入
java
亦暖筑序19 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰6751 天前
字节跳动国际支付-后端开发-三面面经
java
Flittly1 天前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring