checkstyle配置文件说明(checkstyle 3.5)

属性 说明
basedir代码所在的位置
AbstractClassNameformat: 定义抽象类的命名规则
PackageNameformat: 定义包名的命名规则
TypeNameformat: 定义类和接口的命名规则
tokens: 定义规则适用的类型,例如:CLASS_DEF表示类,INTERFACE_DEF 表示接口
ParameterNameformat: 定义参数名的命名规则
ParameterNumbermax: 定义最多有多少个参数
tokens: 定义检查的类型
StaticVariableNameformat: 定义静态变量的命名规则
MethodNameformat: 定义方法名的命名规则
LeftCurlyoption: 定义左大括号'{'显示位置,eol在同一行显示,nl在下一行显示
maxLineLength: 大括号'{'所在行行最多容纳的字符数
tokens: 该属性适用的类型,例:CLASS_DEF,INTERFACE_DEF,METHOD_DEF,CTOR_DEF
LineLengthmax: 定义一行所能容许的字符数
ignorePattern: 定义可以忽略的格式
MethodLength检查方法的行数
max: 最多容许的行数
countEmpty: 是否计算空行
tokens: 定义检查的类型
RightCurlyoption: 右大括号是否单独一行显示
tokens: 定义检查的类型
PackageHtml检查对每一个包是否生成了package.html文件
fileExtensions: 指定要检查的文件的类型,如果只包含java文件,就不必指定
JavadocType检查类或者接口的javadoc注释
authorFormat: 检查author标签的格式
versionFormat: 检查version标签的格式
scope: 可以检查的类的范围,例如:public只能检查public修饰的类,private可以检查所有的类
excludeScope: 不能检查的类的范围,例如:public,public的类将不被检查,但访问权限小于public的类仍然会检查,其他的权限以此类推
tokens: 该属性适用的类型,例如:CLASS_DEF,INTERFACE_DEF
JavadocMethod检查方法的javadoc的注释
scope: 可以检查的方法的范围,例如:public只能检查public修饰的方法,private可以检查所有的方法
allowMissingParamTags: 是否忽略对参数注释的检查
allowMissingThrowsTags: 是否忽略对throws注释的检查
allowMissingReturnTag: 是否忽略对return注释的检查
JavadocVariable检查类变量的注释
scope: 检查变量的范围,例如:public只能检查public修饰的变量,private可以检查所有的变量
JavadocStylescope:
excludeScope:
checkFirstSentence:
checkEmptyJavadoc:
checkHtml:
tokens:
LocalVariableNameformat: 定义局部变量的命名规则
LocalFinalVariableNameformat: 定义局部常量的命名规则
ConstantNameformat: 定义全局常量的命名规则
MemberNameformat: 定义非静态成员变量的命名规则
applyToPublic: 是否适用于public的成员变量
applyToProtected: 是否适用于protected的成员变量
applyToPackage: 是否适用于package的成员变量
applyToPrivate: 是否适用于private的成员变量
AvoidStarImport必须导入类的完整路径,即不能使用*导入所需的类
excludes: 定义可以使用*导入的包
ImportOrder定义导入包的顺序
groups: 定义导入包的顺序,默认以字母顺序导入
ordered: 定义包是否必须按规定的顺序显示
separated: 定义包与包之间是否应添加空白行
caseSensitive: 是否区分包名的大小写
IllegalImport检查是否从非法的包中导入了类
illegalPkgs: 定义非法的包名称
UnusedImports检查是否导入的包没有使用
RedundantImport检查是否导入了不必显示导入的类
EmptyForInitializerPad检查for语句初始化变量的格式
option: 定义初始化语句中是否使用空格,例如:space表示使用空格,则for(int i = 0; i < 100; i++)就是符合格式要求的,而for(int i=0; i<100;i++)就不符合要求
EmptyForIteratorPad检查for iterator语句是否使用空格
option: 定义初始化语句是否使用空格,例如:space表示使用空格,则for(Iterator iterator = List.iterator(); iterator.hasNext(); iterator.next())就是形式合理的,否则就是形式不合理的
ExecutableStatementCount检查要执行的语句的数目
max: 定义所能容许的语句的最多数目
tokens: 定义可以检查的类型,例如:CTOR_DEF,METHOD_DEF,STATIC_INIT,INSTANCE_INIT
FileLengthmax: 定义一个文件所能容许的行数
AnonInnerLength检查匿名内部类
max: 定义匿名内部类最多容许的行数
MethodParamPad检查方法参数的格式
allowLineBreaks: 参数是否允许在不同行(注:没有作用)
option: 在参数和括号、参数和标识符之间是否包含空格
OperatorWrap检查运算符是否在应在同一行
option: 定义运算符的位置,eol在同一行,nl在下一行
tokens: 定义检查的类型
ParenPad检查左小括号'('后边和右小括号')'前边是否有空格
option: space表示有空格,nospace表示没有空格
tokens: 定义检查的类型
TypecastParenPad暂不清楚
TabCharacter检查源码中是否包含\t
WhitespaceAfter检查类型后是否包含空格
tokens: 检查的类型
WhitespaceAround暂不清楚
ModifierOrder检查修饰符的顺序,默认是 public,protected,private,abstract,static,final,transient,volatile,synchronized,native,strictfp(注:定义不起作用)
RedundantModifier检查是否有多余的修饰符,例如:接口中的方法不必使用public、abstract修饰
tokens: 检查的类型
EmptyBlock检查是否有空代码块
option: 定义代码块中应该包含的内容,例如:stmt表示语句
tokens: 检查的类型
NeedBraces检查是否应该使用括号的地方没有加括号
tokens: 定义检查的类型
AvoidNestedBlocks检查是否有嵌套的代码块
allowInSwitchCase: 定义是否允许switch case中使用嵌套的代码块
ArrayTrailingComma检查初始化数祖时,最后一个元素后面是否加了逗号,如果左右大括号都在同一行,则可以不加逗号
AvoidInlineConditionals检查是否在同一行初始化, 例如:private int Age = nGe==1 ? 100 : 0; 就应该避免
CovariantEquals暂不清楚
ModifiedControlVariable检查循环控制变量是否被修改
SimplifyBooleanExpression检查是否有boolean使用冗余的地方,例如:b == true、b || true,应该简化为 b、b
SimplifyBooleanReturn检查是否在返回boolean值时是否有使用冗余的地方,例如:
if(valid())
return true;
else
return false;
应该改为:
return valid();
StringLiteralEquality检查在判断字符串是否相等时是否使用了正确的形式
EqualsHashCode检查在重写了equals方法后是否重写了hashCode方法
FinalLocalVariable检查变量值没有改动的情况下,该变量是否定义成了final
MissingSwitchDefault检查switch语句是否忘记了default标签
RedundantThrows检查是否抛出了多余的异常
DefaultComesLast检查switch中default是否在所有case的后面
MissingCtor检查类中是否显式定义了构造器
FallThrough检查switch中case后是否加入了跳出语句,例如:return、break、throw、continue
MultipleStringLiterals检查一个字符串变量在不改变变量值的情况下或者字符串出现的次数
allowedDuplicates: 定义在类中一个字符串变量在不改变变量值的情况下或者字符串所能使用的最多次数
MultipleVariableDeclarations检查一次声明多个变量时,变量是否在同一行或者在同一个语句中
RequireThis检查是否使用了this
checkFields: 是否检查变量引用
checkMethods: 是否检查方法调用
UnnecessaryParentheses检查是否使用了多余的小括号
VisibilityModifier检查变量是否对外部可见
packageAllowed: 变量包内成员可以访问
protectedAllowed: 变量是受保护的
publicMemberPattern: 可以公开访问的变量所匹配的命名形式
FinalClass只有私有构造器的类必须声明为final
InterfaceIsType检查接口是否只定义了变量而没有定义方法,因为接口应该用来描述一个类型,所以只定义变量而不定义方法是不恰当的
allowMarkerInterfaces: 是否检查空接口
HideUtilityClassConstructor只定义了静态方法的类不应该定义一个公有的构造器
DesignForExtension检查类是否被设计为可扩展的,如果是,则方法应该abstract、final或者是空的
ThrowsCount检查抛出异常的数量
max: 定义抛出异常的最大数目
StrictDuplicateCode检查类中是否有代码复制的问题
min: 允许代码重复的最小行数
charset: 文件所用的字符集
BooleanExpressionComplexitymax: 布尔运算符在一条语句中允许出现的最大数目
GenericIllegalRegexp检查代码中是否有不合适的引用形式或者字符
format: 定义检查所匹配的类型
ignoreCase: 是否区分大小写
ignoreComments: 是否忽略注释
message: 出现问题应该显示给用户的信息
NewlineAtEndOfFile检查文件是否以一个新行结束
lineSeparator: 行分隔符的类型,windows是crlf
UncommentedMain检查是否有没有被注掉或者删除的main方法
excludedClasses: 定义可以带main方法的类所匹配的名字形式
UpperEll检查初始化长整型变量时,数字後是加了大写字母'L'而不是小写字母'l'
ArrayTypeStyle检查再定义数组时,采用java风格还是c风格,例如:int[] num是java风格,int num[]是c风格
javaStyle: 定义是否采用java风格定义数组
FinalParameters检查参数是否是常量
tokens: 定义检查的类型
Indentation检查代码的缩进是否符合要求
basicOffset: 定义代码体相对于所属的代码体的缩进量
braceAdjustment: 定义括号的缩进量
caseIndent: 定义case的缩进量
RequiredRegexp检查文件中是否存在相应的文字
format: 定义所匹配的形式
usage.OneMethodPrivateField检查是否只有一个方法访问了私有变量
ignoreFormat: 定义可以忽略的变量所匹配的命名形式
usage.UnusedLocalVariable检查是否有命名後没有使用的变量
ignoreFormat: 定义可以忽略的变量所匹配的命名形式
usage.UnusedParameter检查是否有没有使用的参数
ignoreFormat: 定义可以忽略的变量所匹配的命名形式
ignoreCatch: 是否忽略catch中的参数
ignoreNonLocal: 是否忽略非本地的变量
usage.UnusedPrivateField检查是否存在未被使用的私有成员变量
ignoreFormat: 定义可以忽略的变量所匹配的命名形式
usage.UnusedPrivateMethod检查是否存在未被使用的私有方法
ignoreFormat: 定义可以忽略的变量所匹配的命名形式

上面的内容已经全部包含在附件中,读者可以下载,作为手册察看。

一个checkstyle文件的例子:

Ehoo_checks.xml,checkstyles的配置文件代码 复制代码 收藏代码
  1. <?xmlversion="1.0"?>
  2. <!DOCTYPEmodulePUBLIC
  3. "-//PuppyCrawl//DTDCheckConfiguration1.2//EN"
  4. "http://www.puppycrawl.com/dtds/configuration_1_2.dtd">
  5. <modulename="Checker">
  6. <propertyname="basedir"value="${check.src}"/>
  7. <propertyname="localeCountry"value="CN"/>
  8. <propertyname="localeLanguage"value="cn"/>
  9. <metadataname="com.atlas-sw.eclipse"value="IlikeSydney"/>
  10. <propertyname="severity"value="error"/>
  11. <modulename="SuppressionFilter">
  12. <propertyname="file"value="${check.filter.file}"/>
  13. </module>
  14. <modulename="PackageHtml">
  15. <propertyname="fileExtensions"value="java,properties"/>
  16. </module>
  17. <modulename="Translation">
  18. <propertyname="severity"value="info"/>
  19. </module>
  20. <modulename="StrictDuplicateCode">
  21. <propertyname="min"value="7"/>
  22. <propertyname="charset"value="UTF-8"/>
  23. </module>
  24. <modulename="NewlineAtEndOfFile">
  25. </module>
  26. <modulename="TreeWalker">
  27. <modulename="AbstractClassName">
  28. <propertyname="format"value="^Abstract.*$|^.*Factory$"/>
  29. </module>
  30. <modulename="ImportOrder">
  31. <propertyname="groups"value="java,javax"/>
  32. <propertyname="ordered"value="true"/>
  33. <propertyname="separated"value="true"/>
  34. <propertyname="caseSensitive"value="true"/>
  35. </module>
  36. <modulename="ExecutableStatementCount">
  37. <propertyname="max"value="20"/>
  38. <propertyname="tokens"value="CTOR_DEF,METHOD_DEF,STATIC_INIT,INSTANCE_INIT"/>
  39. </module>
  40. <modulename="AnonInnerLength">
  41. <propertyname="max"value="20"/>
  42. </module>
  43. <modulename="EmptyForInitializerPad">
  44. <propertyname="option"value="space"/>
  45. </module>
  46. <modulename="EmptyForIteratorPad">
  47. <propertyname="option"value="space"/>
  48. </module>
  49. <modulename="MethodParamPad">
  50. <propertyname="allowLineBreaks"value="false"/>
  51. <propertyname="option"value="space"/>
  52. <propertyname="tokens"value="METHOD_DEF,CTOR_DEF"/>
  53. </module>
  54. <modulename="NoWhitespaceAfter">
  55. <propertyname="allowLineBreaks"value="true"/>
  56. </module>
  57. <modulename="NoWhitespaceBefore">
  58. <propertyname="allowLineBreaks"value="true"/>
  59. </module>
  60. <modulename="TypecastParenPad">
  61. <propertyname="option"value="space"/>
  62. </module>
  63. <modulename="ParenPad">
  64. <propertyname="option"value="nospace"/>
  65. </module>
  66. <modulename="WhitespaceAfter">
  67. <propertyname="tokens"value="COMMA,SEMI,TYPECAST"/>
  68. </module>
  69. <modulename="WhitespaceAround">
  70. <propertyname="tokens"value="ASSIGN"/>
  71. </module>
  72. <modulename="ModifierOrder"/>
  73. <modulename="RedundantModifier">
  74. <propertyname="tokens"value="METHOD_DEF,VARIABLE_DEF"/>
  75. </module>
  76. <modulename="AvoidNestedBlocks">
  77. <propertyname="allowInSwitchCase"value="true"/>
  78. </module>
  79. <modulename="MissingSwitchDefault"/>
  80. <modulename="ModifiedControlVariable"/>
  81. <modulename="RedundantThrows">
  82. <propertyname="allowUnchecked"value="true"/>
  83. <propertyname="allowSubclasses"value="true"/>
  84. </module>
  85. <modulename="StringLiteralEquality"/>
  86. <modulename="SuperClone"/>
  87. <modulename="SuperFinalize"/>
  88. <modulename="IllegalCatch"/>
  89. <modulename="PackageDeclaration"/>
  90. <modulename="ReturnCount">
  91. <propertyname="max"value="3"/>
  92. </module>
  93. <modulename="DeclarationOrder"/>
  94. <modulename="ParameterAssignment"/>
  95. <modulename="DefaultComesLast"/>
  96. <modulename="FallThrough"/>
  97. <modulename="MultipleStringLiterals">
  98. <propertyname="allowedDuplicates"value="3"/>
  99. </module>
  100. <modulename="MultipleVariableDeclarations"/>
  101. <modulename="RequireThis">
  102. <propertyname="checkFields"value="false"/>
  103. <propertyname="checkMethods"value="false"/>
  104. </module>
  105. <modulename="UnnecessaryParentheses"/>
  106. <modulename="HideUtilityClassConstructor"/>
  107. <modulename="ThrowsCount">
  108. <propertyname="max"value="7"/>
  109. </module>
  110. <modulename="BooleanExpressionComplexity">
  111. <propertyname="max"value="7"/>
  112. </module>
  113. <modulename="ClassDataAbstractionCoupling">
  114. <propertyname="max"value="7"/>
  115. </module>
  116. <modulename="AvoidInlineConditionals"/>
  117. <modulename="CovariantEquals"/>
  118. <modulename="HiddenField">
  119. </module>
  120. <modulename="InterfaceIsType">
  121. <propertyname="allowMarkerInterfaces"value="true"/>
  122. </module>
  123. <modulename="UncommentedMain">
  124. <propertyname="excludedClasses"value="^$"/>
  125. </module>
  126. <modulename="ArrayTypeStyle">
  127. <propertyname="javaStyle"value="true"/>
  128. </module>
  129. <modulename="Indentation">
  130. <propertyname="basicOffset"value="4"/>
  131. <propertyname="braceAdjustment"value="0"/>
  132. <propertyname="caseIndent"value="4"/>
  133. </module>
  134. <modulename="RequiredRegexp">
  135. <propertyname="format"value="^$"/>
  136. </module>
  137. <modulename="usage.OneMethodPrivateField">
  138. <propertyname="ignoreFormat"value="^$"/>
  139. </module>
  140. <modulename="usage.UnusedLocalVariable">
  141. <propertyname="ignoreFormat"value="^$"/>
  142. </module>
  143. <modulename="usage.UnusedParameter">
  144. <propertyname="ignoreFormat"value="^$"/>
  145. <propertyname="ignoreCatch"value="true"/>
  146. <propertyname="ignoreNonLocal"value="false"/>
  147. </module>
  148. <modulename="usage.UnusedPrivateField">
  149. <propertyname="ignoreFormat"value="^$"/>
  150. </module>
  151. <modulename="usage.UnusedPrivateMethod">
  152. <propertyname="ignoreFormat"value="^$"/>
  153. </module>
  154. <propertyname="cacheFile"value="${checkstyle.dir}/cacheFile"/>
  155. <propertyname="fileExtensions"value="java,ejb,jpf"/>
  156. <propertyname="charset"value="UTF-8"/>
  157. <propertyname="tabWidth"value="4"/>
  158. <modulename="FileContentsHolder">
  159. </module>
  160. <modulename="GenericIllegalRegexp">
  161. <propertyname="format"value="\s$"/>
  162. <propertyname="ignoreCase"value="true"/>
  163. <propertyname="ignoreComments"value="true"/>
  164. <propertyname="message"value="wrongused"/>
  165. </module>
  166. <modulename="AvoidStarImport">
  167. <propertyname="excludes"value="java.io,java.util"/>
  168. </module>
  169. <modulename="ConstantName">
  170. <propertyname="format"value="^[A-Z][A-Z0-9]*(_[A-Z0-9]+)*$"/>
  171. </module>
  172. <modulename="EmptyBlock">
  173. <propertyname="option"value="stmt"/>
  174. </module>
  175. <modulename="EqualsHashCode"/>
  176. <modulename="FileLength">
  177. <propertyname="max"value="1000"/>
  178. </module>
  179. <modulename="IllegalImport">
  180. </module>
  181. <modulename="IllegalInstantiation"/>
  182. <modulename="InnerAssignment"/>
  183. <modulename="JavadocType">
  184. <propertyname="authorFormat"value="\S"/>
  185. <propertyname="scope"value="protected"/>
  186. <propertyname="versionFormat"value="\$Revision.*\$"/>
  187. <propertyname="excludeScope"value="public"/>
  188. <propertyname="tokens"value="CLASS_DEF,INTERFACE_DEF"/>
  189. </module>
  190. <modulename="JavadocMethod">
  191. <propertyname="scope"value="private"/>
  192. <propertyname="allowMissingParamTags"value="false"/>
  193. <propertyname="allowMissingThrowsTags"value="false"/>
  194. <propertyname="allowMissingReturnTag"value="false"/>
  195. <propertyname="tokens"value="METHOD_DEF"/>
  196. <propertyname="allowUndeclaredRTE"value="true"/>
  197. <propertyname="allowThrowsTagsForSubclasses"value="true"/>
  198. </module>
  199. <modulename="JavadocVariable">
  200. <propertyname="scope"value="private"/>
  201. </module>
  202. <modulename="JavadocStyle">
  203. <propertyname="scope"value="public"/>
  204. <propertyname="checkFirstSentence"value="true"/>
  205. <propertyname="checkEmptyJavadoc"value="true"/>
  206. <propertyname="checkHtml"value="true"/>
  207. </module>
  208. <modulename="LeftCurly">
  209. <propertyname="option"value="eol"/>
  210. <propertyname="maxLineLength"value="80"/>
  211. <propertyname="tokens"
  212. value="CLASS_DEF,INTERFACE_DEF,METHOD_DEF,CTOR_DEF"/>
  213. </module>
  214. <modulename="LineLength">
  215. <propertyname="max"value="80"/>
  216. <propertyname="ignorePattern"value="^*\**[^]+$"/>
  217. </module>
  218. <modulename="LocalFinalVariableName">
  219. <propertyname="format"value="^[A_Z][A-Z0-9]*(_[A_Z0-9]+)*$"/>
  220. </module>
  221. <modulename="LocalVariableName">
  222. <propertyname="format"value="^[a-z][a-zA-Z0-9]*$"/>
  223. </module>
  224. <modulename="MemberName">
  225. <propertyname="format"value="^[a-z][a-zA-Z0-9]*$"/>
  226. <propertyname="applyToPublic"value="true"/>
  227. <propertyname="applyToProtected"value="true"/>
  228. <propertyname="applyToPackage"value="true"/>
  229. <propertyname="applyToPrivate"value="true"/>
  230. </module>
  231. <modulename="MethodLength">
  232. <propertyname="max"value="100"/>
  233. <propertyname="countEmpty"value="true"/>
  234. <propertyname="tokens"value="METHOD_DEF"/>
  235. </module>
  236. <modulename="MethodName">
  237. <propertyname="format"value="^[a-z][a-zA-Z0-9]*$"/>
  238. </module>
  239. <modulename="ModifierOrder"/>
  240. <modulename="NeedBraces">
  241. </module>
  242. <modulename="OperatorWrap">
  243. <propertyname="tokens"
  244. value="ASSIGN,DIV,DIV_ASSIGN,PLUS_ASSIGN,MINUS,MINUS_ASSIGN,STAR,STAR_ASSIGN,MOD,MOD_ASSIGN,SR,SR_ASSIGN,BSR,BSR_ASSIGN,SL,SL_ASSIGN,BXOR,BXOR_ASSIGN,BOR,BOR_ASSIGN,BAND,BAND_ASSIGN,PLUS,QUESTION"/>
  245. <propertyname="option"value="eol"/>
  246. </module>
  247. <modulename="PackageName">
  248. <propertyname="format"value="^[a-z]+(\.[a-z][a-z0-9]*)*$"/>
  249. </module>
  250. <modulename="ParameterName">
  251. <propertyname="format"value="^[a-z][a-zA-Z0-9]*$"/>
  252. </module>
  253. <modulename="ParameterNumber">
  254. <propertyname="max"value="10"/>
  255. <propertyname="tokens"value="METHOD_DEF,CTOR_DEF"/>
  256. </module>
  257. <modulename="RedundantImport"/>
  258. <modulename="RedundantModifier"/>
  259. <modulename="RightCurly">
  260. <propertyname="option"value="alone"/>
  261. <propertyname="tokens"value="LITERAL_TRY"/>
  262. </module>
  263. <modulename="SimplifyBooleanExpression"/>
  264. <modulename="SimplifyBooleanReturn"/>
  265. <modulename="StaticVariableName">
  266. <propertyname="format"value="^[a-z][a-zA-Z0-9]*$"/>
  267. </module>
  268. <modulename="TypeName">
  269. <propertyname="format"value="^[A-Z][a-zA-Z0-9]*$"/>
  270. <propertyname="tokens"value="CLASS_DEF,INTERFACE_DEF"/>
  271. </module>
  272. <modulename="UnusedImports"/>
  273. <modulename="UpperEll"/>
  274. <modulename="VisibilityModifier">
  275. <propertyname="packageAllowed"value="false"/>
  276. <propertyname="protectedAllowed"value="false"/>
  277. <propertyname="publicMemberPattern"value="^seriaVersionUID$"/>
  278. </module>
  279. <modulename="WhitespaceAround"/>
  280. <modulename="FinalClass"/>
  281. <modulename="MissingSwitchDefault"/>
  282. <modulename="Indentation">
  283. <propertyname="basicOffset"value="4"/>
  284. <propertyname="braceAdjustment"value="0"/>
  285. <propertyname="caseIndent"value="0"/>
  286. </module>
  287. <modulename="ArrayTrailingComma"/>
  288. <modulename="CyclomaticComplexity">
  289. <propertyname="severity"value="ignore"/>
  290. </module>
  291. <modulename="NestedIfDepth">
  292. <propertyname="max"value="1"/>
  293. </module>
  294. <modulename="NestedTryDepth">
  295. <propertyname="max"value="3"/>
  296. </module>
  297. <modulename="ExplicitInitialization"/>
  298. </module>
  299. </module>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值