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

相关推荐
热爱编程的小刘15 小时前
Lesson05&6 --- C&C++内存管理&模板初阶
开发语言·c++
爬山算法15 小时前
Hibernate(85)如何在持续集成/持续部署(CI/CD)中使用Hibernate?
java·ci/cd·hibernate
菜鸟233号16 小时前
力扣647 回文子串 java实现
java·数据结构·leetcode·动态规划
qq_124987075316 小时前
基于Java Web的城市花园小区维修管理系统的设计与实现(源码+论文+部署+安装)
java·开发语言·前端·spring boot·spring·毕业设计·计算机毕业设计
h7ml16 小时前
查券返利机器人的OCR识别集成:Java Tesseract+OpenCV优化图片验证码的自动解析方案
java·机器人·ocr
野犬寒鸦16 小时前
从零起步学习并发编程 || 第五章:悲观锁与乐观锁的思想与实现及实战应用与问题
java·服务器·数据库·学习·语言模型
Volunteer Technology16 小时前
Sentinel的限流算法
java·python·算法
岁岁种桃花儿16 小时前
SpringCloud从入门到上天:Nacos做微服务注册中心
java·spring cloud·微服务
jdyzzy16 小时前
什么是 JIT 精益生产模式?它与传统的生产管控方式有何不同?
java·大数据·人工智能·jit
Chasmれ16 小时前
Spring Boot 1.x(基于Spring 4)中使用Java 8实现Token
java·spring boot·spring