CheckStyle,定制自己的Java编码规范

前言

一、CheckStyle简介

Checkstyle是一个开发工具,可以帮助程序员编写遵循编码标准的Java代码。它自动化了检查Java代码的过程,以避免人类完成这一枯燥(但很重要)的任务。这使得它非常适合那些希望实施编码标准的项目。Checkstyle是高度可配置的,可以支持几乎任何编码标准,默认内置Sun Java编码规范和Google Java编码规范两套配置文件,我们也可以根据自己的需要配置自己的规范。

二、CheckStyle的安装

与其它的插件一样,CheckStyle插件也提供了直接在AS的仓库中安装和手动离线安装两种方式。

1、直接从AS的插件库下载安装

至于如何在AS插件库中安装插件,在我的另外一篇介绍FindBugs的文章【https://www.cnblogs.com/andy-songwei/p/11820564.html】中已经介绍过了,这里就不赘述了。简单说一下就是File > Settings > Plugins > Browse repositories 搜索 “CheckStyle”,找到“CheckStyle-IDEA”这一项,按照提示进行安装,然后重启即可。笔者采用这种方式安装时,提示了好几次网络异常,资源无响应等现象,不过多尝试几次就好了。

2、手动下载并从磁盘安装

请从如下地址获取离线安装包:

链接:

提取码:

三、使用CheckStyle进行分析

1、启动CheckStyle

(1)在AS的左下角有个“CheckStyle”按钮,从这里可以打开CheckStyle面板,从中启动扫描功能。该面板各项功能在下文会详细介绍。

(2)在Java文件的编辑界面点击右键,在弹出的菜单中找到“Check Current File”,点击即可开始扫描。默认是检测当前文件,在控制面板中可以选择检测范围。

2、检查结果

检查完后会显示如下CheckStyle面板,会展示检查出来的各项问题点。该面板各个区域的功能,后面再详细介绍。

通过点击检查结果列表区域,可以定位到问题代码源码处。

四、CheckStyle面板介绍

1、工具栏

(1)Close CheckStyle Window:关闭CheckStyle面板窗口

(2)Stop the running scan:停止当前正在运行的扫描

(3)Check Current File:在编辑器中当前文件上运行CheckStyle

(4) Check Module:在当前Module上运行CheckStyle

(5)Check Project:在当前项目上运行CheckStyle

(6)Check All Modified Files:检查所有修改的文件,结合版本控制工具一起使用。

(7)Check Files in the Current Change List:检查当前change list中的文件

(8)Reload Rules files:清理规则文件(即配置文件)缓存和黑名单,强制重新加载改变后的规则文件。

(9)Autoscroll to Source:自动滚动到错误和警告的源码位置处。

(10)Expand All:展开所有工具窗口(即控制面板)的元素

(11)Collapse All:收起所有工具窗口的元素

(12)Display Errors:展示错误,结果窗口会显示

(13)Dispaly Warnings:展示警告

(14)Display Information Results:展示信息结果

对照说明和每一项的运行结果,各个功能项的作用就很容易理解了。

2、选择检查规则

②处需要事先选择好扫描所采用的代码规范配置文件,默认是没有选择的。

默认这里只有“Sun Checks”和“Google Checks”,“Huawei_CheckStyle”是华为的规范配置,“songwei-style”是自己配置的规范。选择其中某项后,才能以该项对应的配置文件来进行检查。如何添加/删除配置文件,后文会再讲到。

3、检查结果列表

③处显示检查后的结果,以树状结果展示。点击具体某一项后,可以直接跳到问题代码处。

五、配置CheckStyle

File > Settings > Checkstyle就可进入到如下配置界面。

这里我们介绍部分区域功能,其它部分比较简单,就不多说了。

1、扫描范围

选择扫描范围,每一项含义比较简单,就不多介绍了。

2、管理配置文件(这一项很重要)

这里面默认的只有“Sun Checks”和“Google Checks”,后面有“bundled”标识,标识是捆绑在CheckStyle插件中的。要采用哪套规则作为规范标准,需要选中该项。左边的按钮就是添加新的配置文件或者对选中的配置项删除或者编辑。这里着重介绍一下添加新配置项,点击“+”按钮弹出如下对话框:

配置好后,按照向导操作即可。

六、定制配置文件

由于Sun和Google的检查过于严格,所以一般我们需要自己配置或者使用国内业界比较知名的成熟配置方案,比如华为的配置文件。如果我们要完全自己定制的话,可以参照Sun、Google、华为等的模板进行修改。这里提供这三种配置文件的路径:

(1)华为配置文件

链接:https://pan.baidu.com/s/1tlvHtezgjwRIUA8DBVYFUQ

提取码:qxji

(2)Sun Check配置文件

https://github.com/checkstyle/checkstyle/blob/master/src/main/resources/sun_checks.xml

(3)Google Check配置文件

https://github.com/checkstyle/checkstyle/blob/master/src/main/resources/google_checks.xml

这些文件都是以 <module>...</module>对的形式组成的,这每一对就表示了一条匹配的规则。如下就是一条对“JavadocType”的匹配规则,如果不需要检查这一项,可以直接注释掉,或者根据需要做其它修改。

1 <module name="JavadocType">
2     <property name="authorFormat" value="\S"/>
3     <property name="scope" value="protected"/>
4     <property name="tokens" value="CLASS_DEF,INTERFACE_DEF"/>
5 </module>

如果需要了解每一个属性的作用等更深入的知识,可以查看CheckStyle官网:https://checkstyle.org/index.html进行学习,这里就不深入介绍了。

原文地址:https://www.cnblogs.com/andy-songwei/p/11824958.html

时间: 2024-10-26 07:53:44

CheckStyle,定制自己的Java编码规范的相关文章

java编码规范

右括号") "与其后面的关键字之间,关键字与其后面的左括号"("或"{"之间,以及"}"与"{"之间,要以一个空格隔开:除". "外,所有二元操作符的前.后要加空格:在逗号后边加一个空格. 说明: 一个紧跟着括号的关键词应该被空格分开: 空白应该位于参数列表中逗号的后面: 所有的二元运算符,除了".",应该使用空格将之与操作数分开.一元操作符和操作数之间不应该加空格,

阿里Java编码规范

详细,全面 很不错 阿里 Java编码规范

个人整理--Java编码规范

编码规范对于开发人员来说是非常重要的,有以下几个原因: 1.一个软件的生命周期中,80%的花费在于维护 2.几乎没有任何一个软件,在其整个生命周期中,均由最初的开发人员来维护 3.编码规范可以改善软件的可读性,可以让程序员尽快而彻底地理解新的代码 4.如果你将源码作为产品发布,就需要确任它是否被很好的打包并且清晰无误,一如你已构建的其它任何产品 5.为来自不同的项目组或个人提供标准的代码格式. 6.增加易读性. 在不用Java两年多后因工作需要我又要转入Java开发,为此我整理出下面的编码规范,

Java 编码规范

参考Sun公司的Java编码规范,半翻译半理解. 使用空行分割代码块,并给代码块添加注释: 一个文件一个类(或者接口),将私有类放在引用该类的公用类的后面: 源文件构成:文件注释.package/import.类或接口的声明: /* * Class name * Version info * Copyright notice * Program description */ 使用4个空格作为缩进,避免使用Tab键(Tab键还没有统一的标准,有的是4个空格,有的是8个空格): 控制每行代码的长度,

java编码规范及优化总结

一.java概述 1991 年Sun公司的James Gosling(詹姆斯·高斯林)等人开始开发名称为 Oak 的语言,希望用于控制嵌入在有线电视交换盒.PDA等的微处理器.1994年将Oak语言更名为Java. 二.Java的三种技术架构 J2EE:Java PlatformEnterprise Edition,开发企业环境下的应用程序,主要针对web程序开发: J2SE:Java PlatformStandard Edition,完成桌面应用程序的开发,是其它两者的基础: J2ME:Jav

oracle Java编码规范

最近看java编码规范,借鉴petercao的原文翻译并做了改动,还有没有改完的地方,欢迎指正. 原文地址如下 http://www.cnblogs.com/bluestorm/archive/2012/10/04/2711540.html Oracle官方Java编码规范(英文版) http://www.oracle.com/technetwork/java/codeconvtoc-136057.html 1 介绍(Introduction) 1.1 为什么要有编码规范(Why Have Co

规定自己的Java编码规范

给自己规定了Java编码规范,编写Java代码严格按照自己规定的格式.欢迎大家指出问题. /* *COPYRIGHT */ package com.triangle23.projectabbreviationname.modulename.???.???. ##1.所有字母都是用小写,不要有特殊字符 ##2.组合单词的每个部分都写全拼,连接时各个部分之间不要有特殊符号,组合单词不要超过三个,每个部分都用名词,尽量用英文,中文的话用拼音 ##3.projectabbreviationname和mo

标准的Java编码规范手册

编码规范体现出一个开发者的基本素质,良好的编码规范可以提高团队编码的效率,避免很多不必要的问题.今天分享一个标准的Java编码规范给大家,希望对于大家今后的开发工作带来帮助. 编码规范的意义 在项目开发维护中,编码规范作为开发规范的一个组成部分,是十分重要和必须的,它不仅仅是为了提高开发效率,也有利于降低后期维护开发的成本.编码规范的根本目的就是要让不仅代码可以一目了然,也可以很容易的理解开发人员所编写的代码程的用途和意义.由此,用来减少项目中因为开发维护人员的更替或由于长时间不维护造成的记忆模

Java 编码规范(转)

本文转自:http://www.javaranger.com/archives/390 文章总结出了java编码过程中的一些规范,以便参考. 1.合理组织代码层次,分层清晰:controller.logic.dao.对第三方接口(包括公司接口)的调用:各层要继承基类或实现接口 2.先定义方法原型,再实现方法体 3.理想的方法,是不可拆分的.原子的一个逻辑实现,具有一个明确的职责 4.方法体不超过70行,类体不超过500行 5.类名称.变量名称.方法名称,遵循简单明确,知名见义原则.建议不带数字,