Eclipse的插件checkStyle結(jié)果分析
安裝checkStyle插件以及配置
安裝:直接update,添加更新源地址:http://eclipse-cs.sf.net/update/,也可以從http://sourceforge.net/projects/eclipse-cs/files/ 下載最新的插件包本地進(jìn)行安裝。
配置:默認(rèn)安裝有2個(gè)檢查的配置文件,如下圖,Type為Build-In的是默認(rèn)的,可以自己按照內(nèi)置的Copy一個(gè)出來后進(jìn)行修改,或者Import已經(jīng)存在的檢查xml配置文件。
配合著使用的還有一個(gè)Codestyle,如下圖,設(shè)計(jì)到有Clean up、Template、Formatter等幾個(gè)選項(xiàng),默認(rèn)的Eclopse 提供的Clean up好像什么事情都沒做,所以最好是自己新建一個(gè)或者是導(dǎo)入一個(gè)。
常見提示解釋
1、Type is missing a javadoc commentClass 缺少類型說明
2、“{” should be on the previous line“{” 應(yīng)該位于前一行。解決方法:把“{”放到上一行去
3、Methos is missing a javadoc comment 方法前面缺少javadoc注釋。解決方法:添加javadoc注釋 類似這樣:
- /**
- * set default mock parameter.(方法說明)
- * @param additionalParameters parameter additional(參數(shù)名稱)
- * @return data manager(返回值說明)
- * @throws Exception if has error(異常說明)
- */
4、Expected @throws tag for “Exception”在注釋中希望有@throws的說明
解決方法:在方法前得注釋中添加這樣一行:* @throws Exception if has error(異常說明)
5、“.” Is preceeded with whitespace “.” 前面不能有空格。解決方法:把“(”前面的空格去掉
6、“.” Is followed by whitespace“.” 后面不能有空格。解決方法:把“)”后面的空格去掉
7、“=” is not preceeded with whitespace“=” 前面缺少空格。解決方法:在“=”前面加個(gè)空格
8、“=” is not followed with whitespace“=” 后面缺少空格。解決方法:在“=”后面加個(gè)空格
9、“}” should be on the same line“}” 應(yīng)該與下條語句位于同一行。解決方法:把“}”放到下一行的前面
10、Unused @param tag for “unused”沒有參數(shù)“unused”,不需注釋
解決方法:“* @param unused parameter additional(參數(shù)名稱)” 把這行unused參數(shù)的注釋去掉“
11、Variable “CA” missing javadoc變量“CA”缺少javadoc注釋
解決方法:在“CA“變量前添加javadoc注釋:/** CA. */(注意:一定記得加上“.”)
12、Line longer than 80characters行長度超過80 。解決方法:把它分成多行寫。必要時(shí)候,可以ctrl+shift+f
13、Line contains a tab character行含有”tab” 字符??焖俳鉀Q方法:可以使用editplus中的format功能,把tab字符轉(zhuǎn)化為空格,然后保存Editplus英文版安裝文件在我機(jī)子上有。需要的可以來拷貝。注冊(cè)Editplus,點(diǎn)擊安裝文件中注冊(cè)的文件
14、Redundant “Public” modifier冗余的“public” modifier 。解決方法:冗余的“public”
15、Final modifier out of order with the JSL suggestion Final modifier的順序錯(cuò)誤
16、Avoid using the “.*” form of importImport格式避免使用“.*”
17、Redundant import from the same package從同一個(gè)包中Import內(nèi)容
18、Unused import-java.util.listImport進(jìn)來的java.util.list沒有被使用。解決方法:去掉導(dǎo)入的多余的類
19、Duplicate import to line 13重復(fù)Import同一個(gè)內(nèi)容 解決方法:去掉導(dǎo)入的多余的類
20、Import from illegal package從非法包中 Import內(nèi)容
21、“while” construct must use “{}” “while” 語句缺少“{}”
22、Variable “sTest1” must be private and have accessor method變量“sTest1”應(yīng)該是private的,并且有調(diào)用它的方法
23、Variable “ABC” must match pattern “^[a-z][a-zA-Z0-9]*$”變量“ABC”不符合命名規(guī)則“^[a-z][a-zA-Z0-9]*$”解決方法:把這個(gè)命名改成符合規(guī)則的命名 “aBC”
24、“(” is followed by whitespace“(” 后面不能有空格 25“)”is proceeded by whitespace“)” 前面不能有空格
解決方法:把前面或者后面的空格去掉
25、First sentence should end with a period.解決方法:你的注釋的第一行文字結(jié)束應(yīng)該加上一個(gè)"."。
26、Redundant throws: 'NameNotFoundException' is subclass of 'NamingException'. 'NameNotFoundException '是'NamingException'的子類重復(fù)拋出異常。
解決方法:如果拋出兩個(gè)異常,一個(gè)異常類是另一個(gè)的子類,那么只需要寫父類
去掉NameNotFoundException異常,對(duì)應(yīng)的javadoc注釋異常注釋說明也需要去掉
27、Parameter docType should be final. 參數(shù)docType應(yīng)該為final類型 解決方法:在參數(shù)docType前面加個(gè)final
28、Line has trailing spaces. 多余的空行 解決方法:去掉這行空行
29、Must have at least one statement. 至少一個(gè)聲明
解決方法:} catch (NumberFormatException nfe) {
LOG.error("Auto Renews the agreement failed", nfe);//異常捕捉里面不能為空,在異常里面加一句話。如打印等等
30、'>' is not followed by whitespace.并且又有 '(' is preceded with whitespace.
定義集合和枚舉的時(shí)候的時(shí)候,最后一個(gè)“>”后面要有空格,“(”前面不容許有空格。解決方法:去掉泛型
31、Got an exception - java.lang.RuntimeException: Unable to get class information for @throws tag 'SystemException'.原因:不合理的throws。
解決方法:要確保某些類型,如某些類、接口不被throws。把聲明的異常去掉。在實(shí)現(xiàn)類中拋出異常
網(wǎng)上參考解決方法:
1)這是CheckStyle報(bào)的錯(cuò)。通常需要Refreh, clean/build這個(gè)Project. 如果不行,可以嘗試clean all projects, restart Eclipse.
2)因?yàn)榫幾g好的類沒有在checkstyle的classpath中.所以, 只要將編譯好的class配置到在<checkstyle/>的classpath中就沒有這個(gè)問題了.另外, 還發(fā)現(xiàn)checkstyle的line length好像也有點(diǎn)問題, 明明沒有超過120個(gè)字符, 卻還是報(bào)錯(cuò).無奈, 我把Eclipse中java > code style > formatter中的Maximum line with改成了100, 然后format一下, 基本就沒有問題了
32、File does not end with a newline.解決方法:刪掉報(bào)錯(cuò)的類,新建一個(gè)同名的類,把代碼全部復(fù)制過去
33、Utility classes should not have a public or default constructor. 接口中的內(nèi)部類中不應(yīng)該有公共的或者默認(rèn)的構(gòu)造方法
解決方法:在內(nèi)部類中,定義一個(gè)私有的構(gòu)造方法,然后內(nèi)部類聲明為final類型。如果前面有static,那么final還必須放在static之后
34、Variable 'functionCode' must be private and have accessor methods.變量要改成private然后提供訪問的方法
解決方法:給這些變量的修飾符改成private,然后提供set,get方法,并加上對(duì)應(yīng)的方法javadoc注釋、參數(shù)注釋。并在返回值和參數(shù)類型前添加final。并把調(diào)用了這個(gè)變量的地方改成通過方法訪問
35、'X' hides a field.
- public class Foo
- {
- private int bar;
- public Foo(int bar)
- {
- this.bar = bar;
- }
- public final int getBar()
- {
- return bar;
- }
- }
全局private int bar;和局部public Foo(int bar)的bar變量名字重復(fù)。
解決方法:把方法里面的參數(shù)名稱改變下就可以了。
- public Foo(int newBar)
- {
- this.bar = newBar;
- }
36、Got an exception - Unexpected character 0xfffd in identifier
這是因?yàn)镃heckStyle不能識(shí)別制定的編碼格式。
網(wǎng)上參考解決方法:
1)Eclipse中可以配置,在Other-->checker中可以指定
2)可以修改checkstyle配置文件:
- <module name="Checker">
- <property name="severity" value="warning"/>
- <property name="charset" value="UTF-8"/>
- <module name="TreeWalker">
如果是UTF-8的話,就添加加粗斜體的那條語句,就可以了。
37、Got an exception - java.lang.RuntimeException: Unable to get class information for @throws tag *whatever*.
網(wǎng)上參考解決方法:選中CheckSytle的JavaDoc --> Method JavaDoc --> logLoadErrors。如果是CheckStyle自己加載時(shí)出錯(cuò)的,打個(gè)Log就可以了,不要整出Errors嚇人。
還有一處也可能包出同樣的錯(cuò)誤。Coding Problems --> Redundant Throws --> logLoadErrors選中即可
38、Expected @param tag for 'dataManager'. 缺少dataManager參數(shù)的注釋 解決方法:在注釋中添加@param dataManager DataManager
網(wǎng)上一些其他錯(cuò)誤的解答:
1)Parameter X should be final.
- public class Foo
- {
- private int bar;
- public Foo(int bar)
- {
- this.bar = bar;
- }
- public final int getBar()
- {
- return bar;
- }
- }
解釋:public Foo(int bar)的局部變量,被認(rèn)為是不可改變的,檢查需要加上final關(guān)鍵字定義public Foo(final int bar)此錯(cuò)誤,可以忽略不檢查。
2)Redundant 'X' modifier.
- public interface CacheHRTreeService extends Manager {
- /**
- * Organization Tree
- * @param orgDto
- * @return
- * @throws Exception
- */
- public void setOrganization(OrganizationDTO orgDto) throws Exception;
- /**
- * Organization Tree
- * @return
- * @throws Exception
- */
- public OrganizationDTO getOrganization() throws Exception;
- ......
- }
解釋:多余的字段。public OrganizationDTO getOrganization() throws Exception;此時(shí)public為多余的字段,因?yàn)閕nterface定義的時(shí)候,就是public的。
需要檢查。
3)- Class X should be declared as final.
解釋:對(duì)于單例設(shè)計(jì)模式,要求返回唯一的類對(duì)象。但是HRFactory和ContextFactory為優(yōu)化的兩個(gè)類,不需求檢查。
其他的單例類,依然需要進(jìn)行檢查。
4)- Method 'addChildrenId' is not designed for extension - needs to be
abstract, final or empty.
解釋:通過父類繼承的,此類有點(diǎn)特殊可以忽略此類。
5)Variable 'id' must be private and have accessor methods.解釋:BaseHRDTO類,為父類,屬性給子類繼承,比較特殊。但是其他的類,聲名需要加上范圍'private'關(guān)鍵字。需要檢查。
6)-Array brackets at illegal position.解釋:代碼寫法,習(xí)慣不一樣。需要檢查,僅僅提示。
原文鏈接:http://www.cnblogs.com/bluesky4485/archive/2011/11/30/2269198.html
【編輯推薦】