Skip to content

Latest commit

 

History

History
148 lines (82 loc) · 7.8 KB

improve-code.md

File metadata and controls

148 lines (82 loc) · 7.8 KB
title category tag
IDEA 代码优化必备插件总结
IDEA 指南
IDEA
IDEA 插件
代码优化

Lombok: 帮你简化代码

之前没有推荐这个插件的原因是觉得已经是人手必备的了。如果你要使用 Lombok 的话,不光是要安装这个插件,你的项目也要引入相关的依赖。

<dependency>
  <groupId>org.projectlombok</groupId>
  <artifactId>lombok</artifactId>
  <optional>true</optional>
</dependency>

使用 Lombok 能够帮助我们少写很多代码比如 Getter/Setter、Constructor 等等。

关于 Lombok 的使用,可以查看 《十分钟搞懂 Java 效率工具 Lombok 使用与原理》

Codota: 代码智能提示

::: note

目前 Codota 已经更名为 Tabnine

:::

我一直在用的一个插件,可以说非常好用了(我身边的很多大佬平时写代码也会用这个插件)。

Codota 这个插件用于智能代码补全,它基于数百万 Java 程序,能够根据程序上下文提示补全代码。相比于 IDEA 自带的智能提示来说,Codota 的提示更加全面一些。

除了代码补全之外,Codota 还支持代码智能搜索,直接选中对应的类或者方法即可搜索相关的代码示例。

Codota2

如果你觉得 IDEA 插件安装的太多比较卡顿的话,不用担心!Codota 插件还有一个对应的 在线网站,在这个网站上你可以根据代码关键字搜索相关代码示例,非常不错!

我在工作中经常会用到,说实话确实给我带来了很大便利,比如我们搜索 Files.readAllLines 相关的代码,搜索出来的结果如下图所示:

Codota3

另外,Codota 插件的基础功能都是免费的。你的代码也不会被泄露,这点你不用担心。

类似的插件还有阿里云智能编码插件 Cosy(Alibaba Cloud AI Coding Assistant) ,关于 Cosy 的详细介绍,可以看一下我写的 阿里云 Java 智能编码插件 Cosy 诞生! 这篇文章。

Alibaba Java Code Guidelines: 阿里巴巴 Java 代码规范

阿里巴巴 Java 代码规范,对应的 Github 地址为: https://github.com/alibaba/p3c 。非常推荐安装!

安装完成之后建议将与语言替换成中文,提示更加友好一点。

Alibaba-Java-Code-Guidelines2

根据官方描述:

目前这个插件实现了开发手册中的的 53 条规则,大部分基于 PMD 实现,其中有 4 条规则基于 IDEA 实现,并且基于 IDEA Inspection实现了实时检测功能。部分规则实现了 Quick Fix 功能,对于可以提供 Quick Fix 但没有提供的,我们会尽快实现,也欢迎有兴趣的同学加入进来一起努力。 目前插件检测有两种模式: 实时检测、手动触发。

上述提到的开发手册也就是在 Java 开发领域赫赫有名的《阿里巴巴 Java 开发手册》。

手动配置检测规则

你还可以手动配置相关 inspection 规则:

Alibaba-Java-Code-Guidelines3

使用效果

这个插件会实时检测出我们的代码不匹配它的规则的地方,并且会给出修改建议。比如我们按照下面的方式去创建线程池的话,这个插件就会帮我们检测出来,如下图所示。

Alibaba-Java-Code-Guidelines1

这个可以对应上 《阿里巴巴 Java 开发手册》 这本书关于创建线程池的方式说明。

CheckStyle: Java 代码格式规范

为何需要 CheckStyle 插件?

CheckStyle 几乎是 Java 项目开发必备的一个插件了,它会帮助我们检查 Java 代码的格式是否有问题比如变量命名格式是否有问题、某一行代码的长度是否过长等等。

在项目上,通过项目开发人员自我约束来规范代码格式必然是不靠谱的! 因此,我们非常需要这样一款工具来帮助我们规范代码格式。

如果你看过我写的轮子的话,可以发现我为每一个项目都集成了 CheckStyle,并且设置了 Git Commit 钩子,保证在提交代码之前代码格式没有问题。

::: info Guide 哥造的轮子 (代码简洁,结构清晰,欢迎学习,欢迎一起完善)

  1. guide-rpc-framework: A custom RPC framework implemented by Netty+Kyro+Zookeeper.(一款基于 Netty+Kyro+Zookeeper 实现的自定义 RPC 框架-附详细实现过程和相关教程)
  2. jsoncat: 仿 Spring Boot 但不同于 Spring Boot 的一个轻量级的 HTTP 框架

::: info Git 钩子

Git 能在特定的重要动作比如 commit、push 发生时触发自定义脚本。 钩子都被存储在 Git 目录下的 hooks 子目录中。 也即绝大部分项目中的 .git/hooks

:::

如何在 Maven/Gradle 项目中集成 Checksytle?

一般情况下,我们都是将其集成在项目中,并设置相应的 Git 钩子。网上有相应的介绍文章,这里就不多提了。

如果你觉得网上的文章不直观的话,可以参考我上面提到了两个轮子:

  1. guide-rpc-framework: Maven 项目集成 Checksytle。
  2. jsoncat: Gradle 项目集成 Checksytle。

如果你在项目中集成了 Checksytle 的话,每次检测会生成一个 HTML 格式的文件告诉你哪里的代码格式不对,这样看着非常不直观。通过 Checksytle 插件的话可以非常直观的将项目中存在格式问题的地方显示出来。

如果你只是自己在本地使用,并不想在项目中集成 Checksytle 的话也可以,只需要下载一个 Checksytle 插件就足够了。

如何安装?

我们直接在 IDEA 的插件市场即可找到这个插件。我这里已经安装好了。

安装插件之后重启 IDEA,你会发现就可以在底部菜单栏找到 CheckStyle 了。

如何自定义检测规则?

如果你需要自定义代码格式检测规则的话,可以按照如下方式进行配置(你可以导入用于自定义检测规则的CheckStyle.xml文件)。

使用效果

配置完成之后,按照如下方式使用这个插件!

run-check-style

可以非常清晰的看到: CheckStyle 插件已经根据我们自定义的规则将项目中的代码存在格式问题的地方都检测了出来。

SonarLint:帮你优化代码

SonarLint 帮助你发现代码的错误和漏洞,就像是代码拼写检查器一样,SonarLint 可以实时显示出代码的问题,并提供清晰的修复指导,以便你提交代码之前就可以解决它们。

并且,很多项目都集成了 SonarQube,SonarLint 可以很方便地与 SonarQube 集成。