1 Star 1 Fork 295

用心就好~~ / porter

forked from sxfad / porter 
Create your Gitee Account
Explore and code with more than 5 million developers,Free private repositories !:)
Sign up
This repository doesn't specify license. Without author's permission, this code is only for learning and cannot be used for other purposes.
Clone or download
checkstyle.xml 17.16 KB
Copy Edit Web IDE Raw Blame History
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE module PUBLIC "-//Puppy Crawl//DTD Check Configuration 1.2//EN" "http://www.puppycrawl.com/dtds/configuration_1_2.dtd">
<!-- Generated by RHY @will_awoke -->
<module name="Checker">
<property name="charset" value="UTF-8"/>
<property name="severity" value="warning"/>
<!-- Checks for Size Violations. -->
<!-- 检查文件的长度(行) default max=2000 -->
<module name="FileLength">
<property name="max" value="2500"/>
<!-- 检查文件中是否含有'\t' -->
<module name="FileTabCharacter"/>
<!-- Checks that property files contain the same keys. -->
<!-- 检查**.properties配置文件 是否有相同的key -->
<module name="Translation"> </module>
<module name="TreeWalker">
<!-- Checks for imports -->
<!-- 必须导入类的完整路径,即不能使用*导入所需的类
<module name="AvoidStarImport"/>
<!-- defaults to sun.* packages -->
<!-- 检查是否导入了不必显示导入的类 -->
<module name="RedundantImport"/>
<!-- 检查是否导入的包没有使用 -->
<module name="UnusedImports"/>
<!-- Checks for whitespace -->
<!-- Iterator -->
<!-- <module name="EmptyForIteratorPad"/> -->
<!-- 方法名后跟左圆括号"(" -->
<module name="MethodParamPad"/>
<!-- 检查在某个特定关键字之后应保留空格 -->
<module name="NoWhitespaceAfter"/>
<!-- 检查在某个特定关键字之前应保留空格 -->
<module name="NoWhitespaceBefore"/>
<!-- 操作符换行策略检查 -->
<module name="OperatorWrap"/>
<!-- 圆括号空白 -->
<module name="ParenPad"/>
<!-- 在类型转换时,不允许左圆括号右边有空格,也不允许与右圆括号左边有空格 -->
<module name="TypecastParenPad"/>
<!-- 检查分隔符是否在空白之后 -->
<module name="WhitespaceAfter"/>
<!-- 检查分隔符周围是否有空白 -->
<module name="WhitespaceAround"/>
检查类和接口的javadoc 默认不检查author 和version tags
authorFormat: 检查author标签的格式
versionFormat: 检查version标签的格式
scope: 可以检查的类的范围,例如:public只能检查public修饰的类,private可以检查所有的类
excludeScope: 不能检查的类的范围,例如:public,public的类将不被检查,但访问权限小于public的类仍然会检查,其他的权限以此类推
tokens: 该属性适用的类型,例如:CLASS_DEF,INTERFACE_DEF
<module name="JavadocType">
<property name="scope" value="protected"/>
<property name="tokens" value="CLASS_DEF,INTERFACE_DEF"/>
scope: 可以检查的方法的范围,例如:public只能检查public修饰的方法,private可以检查所有的方法
allowMissingParamTags: 是否忽略对参数注释的检查
allowMissingThrowsTags: 是否忽略对throws注释的检查
allowMissingReturnTag: 是否忽略对return注释的检查
<module name="JavadocMethod">
<property name="scope" value="private"/>
<property name="allowMissingParamTags" value="true"/>
<property name="allowMissingThrowsTags" value="true"/>
<property name="allowMissingReturnTag" value="true"/>
<property name="tokens" value="METHOD_DEF"/>
<property name="allowUndeclaredRTE" value="true"/>
<property name="allowThrowsTagsForSubclasses" value="true"/>
<property name="allowMissingPropertyJavadoc" value="true"/>
<!-- 检查javadoc的格式 -->
<module name="JavadocStyle">
<property name="checkFirstSentence" value="false"/>
scope: 检查变量的范围,例如:public只能检查public修饰的变量,private可以检查所有的变量
<module name="JavadocVariable">
<property name="scope" value="public"/>
option: 定义左大括号'{'显示位置,eol在同一行显示,nl在下一行显示
maxLineLength: 大括号'{'所在行行最多容纳的字符数
<module name="LeftCurly">
<property name="option" value="eol"/>
NeedBraces 检查是否应该使用括号的地方没有加括号
tokens: 定义检查的类型
<module name="NeedBraces"/>
Checks the placement of right curly braces ('}') for else, try, and catch tokens. The policy to verify is specified using property option.
option: 右大括号是否单独一行显示
tokens: 定义检查的类型
<module name="RightCurly">
<property name="option" value="alone"/>
<!-- 检查在重写了equals方法后是否重写了hashCode方法 -->
<module name="EqualsHashCode"/>
Checks for illegal instantiations where a factory method is preferred.
Rationale: Depending on the project, for some classes it might be preferable to create instances through factory methods rather than calling the constructor.
A simple example is the java.lang.Boolean class. In order to save memory and CPU cycles, it is preferable to use the predefined constants TRUE and FALSE. Constructor invocations should be replaced by calls to Boolean.valueOf().
Some extremely performance sensitive projects may require the use of factory methods for other classes as well, to enforce the usage of number caches or object pools.
<module name="IllegalInstantiation">
<property name="classes" value="java.lang.Boolean"/>
<!-- Checks for Naming Conventions. 命名规范 -->
<!-- local, final variables, including catch parameters -->
<module name="LocalFinalVariableName"/>
local, non-final variables, including catch parameters
<module name="LocalVariableName"/>
<!-- static, non-final fields -->
<module name="StaticVariableName">
<property name="format" value="(^[A-Z0-9_]{0,40}$)"/>
<!-- packages -->
<module name="PackageName">
<property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$"/>
<!-- classes and interfaces -->
<!-- Class或Interface名检查,默认^[A-Z][a-zA-Z0-9]*$ -->
<module name="TypeName">
<property name="format" value="(^[A-Z][a-zA-Z0-9]{0,40}$)"/>
<property name="severity" value="warning"/>
<!-- methods -->
<module name="MethodName">
<property name="format" value="(^[a-z][a-zA-Z0-9]{0,40}$)"/>
<!-- non-static fields -->
<module name="MemberName">
<property name="format" value="(^[a-z][a-zA-Z0-9]{0,40}$)"/>
<!-- parameters -->
<module name="ParameterName">
<property name="format" value="(^[a-z][a-zA-Z0-9_]{0,40}$)"/>
<!-- constants (static, final fields) -->
<module name="ConstantName">
<property name="format" value="(^[A-Z0-9_]{0,40}$)"/>
<!-- 代码缩进 -->
<module name="Indentation"> </module>
Checks for redundant exceptions declared in throws clause such as duplicates, unchecked exceptions or subclasses of another declared exception.
<module name="RedundantThrows">
<property name="logLoadErrors" value="true"/>
<property name="suppressLoadErrors" value="true"/>
Checks for overly complicated boolean expressions. Currently finds code like if (b == true), b || true, !false, etc.
Rationale: Complex boolean logic makes code hard to understand and maintain.
<module name="SimplifyBooleanExpression"/>
Checks for overly complicated boolean return statements. For example the following code
if (valid())
return false;
return true;
could be written as
return !valid();
The Idea for this Check has been shamelessly stolen from the equivalent PMD rule.
<module name="SimplifyBooleanReturn"/>
Checks that a class which has only private constructors is declared as final.只有私有构造器的类必须声明为final
<module name="FinalClass"/>
Make sure that utility classes (classes that contain only static methods or fields in their API) do not have a public constructor.
Rationale: Instantiating utility classes does not make sense. Hence the constructors should either be private or (if you want to allow subclassing) protected. A common mistake is forgetting to hide the default constructor.
If you make the constructor protected you may want to consider the following constructor implementation technique to disallow instantiating subclasses:
public class StringUtils // not final to allow subclassing
protected StringUtils() {
throw new UnsupportedOperationException(); // prevents calls from subclass
public static int count(char c, String s) {
// ...
<module name="HideUtilityClassConstructor"/>
Checks visibility of class members. Only static final members may be public; other class members must be private unless property protectedAllowed or packageAllowed is set.
检查class成员属性可见性。只有static final 修饰的成员是可以public的。其他的成员属性必需是private的,除非属性protectedAllowed或者packageAllowed设置了true.
Public members are not flagged if the name matches the public member regular expression (contains "^serialVersionUID$" by default). Note: Checkstyle 2 used to include "^f[A-Z][a-zA-Z0-9]*$" in the default pattern to allow CMP for EJB 1.1 with the default settings. With EJB 2.0 it is not longer necessary to have public access for persistent fields, hence the default has been changed.
Rationale: Enforce encapsulation. 强制封装
<module name="VisibilityModifier"/>
<!-- 每一行只能定义一个变量 -->
<module name="MultipleVariableDeclarations"> </module>
Checks the style of array type definitions. Some like Java-style: public static void main(String[] args) and some like C-style: public static void main(String args[])
检查再定义数组时,采用java风格还是c风格,例如:int[] num是java风格,int num[]是c风格。默认是java风格
<module name="ArrayTypeStyle"> </module>
Checks that there are no "magic numbers", where a magic number is a numeric literal that is not defined as a constant. By default, -1, 0, 1, and 2 are not considered to be magic numbers.
<!-- 检查是否有"魔术"数字
<module name="MagicNumber">
<property name="ignoreNumbers" value="0, 1"/>
<property name="ignoreAnnotation" value="true"/>
<property name="ignoreHashCodeMethod" value="true"/>
<property name="ignoreFieldDeclaration" value="true"/>
<property name="tokens" value="NUM_DOUBLE, NUM_FLOAT, NUM_LONG"/>
A check for TODO: comments. Actually it is a generic regular expression matcher on Java comments. To check for other patterns in Java comments, set property format.
检查是否存在TODO(待处理) TODO是javaIDE自动生成的。一般代码写完后要去掉。
<module name="TodoComment"/>
Checks that long constants are defined with an upper ell. That is ' L' and not 'l'. This is in accordance to the Java Language Specification, Section 3.10.1.
looks a lot like 1.
<module name="UpperEll"/>
Checks that switch statement has "default" clause. 检查switch语句是否有‘default’从句
Rationale: It's usually a good idea to introduce a default case in every switch statement.
Even if the developer is sure that all currently possible cases are covered, this should be expressed in the default branch,
e.g. by using an assertion. This way the code is protected aginst later changes, e.g. introduction of new types in an enumeration type.
<!-- 检查switch语句是否有default -->
<module name="MissingSwitchDefault"/>
<module name="FallThrough"/>
Checks the number of parameters of a method or constructor. max default 7个.
<!-- 方法的参数个数不超过5个。 并且不对构造方法进行检查 -->
<module name="ParameterNumber">
<property name="max" value="10"/>
<property name="ignoreOverriddenMethods" value="true"/>
<property name="tokens" value="METHOD_DEF"/>
<!-- 每行字符数 -->
<module name="LineLength">
<property name="max" value="200"/>
Checks for long methods and constructors. max default 150行. max=300 设置长度300
<module name="MethodLength">
<property name="max" value="300"/>
ModifierOrder 检查修饰符的顺序,默认是 public,protected,private,abstract,static,final,transient,volatile,synchronized,native
<module name="ModifierOrder"> </module>
<!-- 检查是否有多余的修饰符,例如:接口中的方法不必使用public、abstract修饰 -->
<module name="RedundantModifier"> </module>
<!-- - 字符串比较必须使用 equals() -->
<module name="StringLiteralEquality"> </module>
<!-- if-else嵌套语句个数 最多3层 -->
<module name="NestedIfDepth">
<property name="max" value="10"/>
<!-- try-catch 嵌套语句个数 最多2层 -->
<module name="NestedTryDepth">
<property name="max" value="5"/>
<!-- 返回个数 -->
<module name="ReturnCount">
<property name="max" value="10"/>
<property name="format" value="^$"/>
<!-- 类设计检查 -->
<!-- 检查类是否为扩展设计l -->
<!-- <module name="DesignForExtension"/> -->
<!-- 检查接口是否仅定义类型 -->
<module name="InterfaceIsType"/>
<!-- 确保一个类有package声明 -->
<module name="PackageDeclaration"/>
<!-- 检查子表达式中是否有赋值操作 -->
<module name="InnerAssignment"/>
其他检查 System\.out\.print,
<module name="GenericIllegalRegexp">
<property name="format" value="printStackTrace"/>
<property name="ignoreComments" value="true" />
<!-- 代码质量 -->
<module name="CyclomaticComplexity">
<property name="max" value="2"/>

Comment ( 0 )

Sign in for post a comment