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

相关推荐
lee_curry6 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣7 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
SmartRadio7 小时前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信
开发语言·网络·智能手机·esp32·长距离wifi
laowangpython8 小时前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫8 小时前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
_.Switch8 小时前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI8 小时前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
Brendan_0018 小时前
JavaScript的Stomp.over
开发语言·javascript·ecmascript
念2348 小时前
f5 shape分析
开发语言·javascript·ecmascript
苍穹之跃8 小时前
某量JS逆向
开发语言·javascript·ecmascript