qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請訪問 http://qaseven.github.io/

          Java中十個常見的違規(guī)編碼

          摘要:作者Veera Sundar在清理代碼工作時發(fā)現(xiàn)一些常見的違規(guī)編碼,因此,Veera Sundar把針對常見的一些違規(guī)編碼總結(jié)成一份列表,以便幫助Java愛好者提高代碼的質(zhì)量和可維護(hù)性。

            最近,我給Java項目做了一次代碼清理工作。經(jīng)過清理后,我發(fā)現(xiàn)一組常見的違規(guī)代碼(指不規(guī)范的代碼并不表示代碼錯誤)重復(fù)出現(xiàn)在代碼中。因此,我把常見的這些違規(guī)編碼總結(jié)成一份列表,分享給大家以幫助Java愛好者提高代碼的質(zhì)量和可維護(hù)性。

            這份列表沒有依據(jù)任何規(guī)則或順序,所有的這些都是通過代碼質(zhì)量工具包括CheckStyle,F(xiàn)indBugs和PMD檢查出。一起來看下:

            一、Eclipse編譯器提供源代碼格式輸入

            Eclipse提供自動源碼格式選項,并且組織輸入(刪除未使用的代碼)。你可以使用下面的這些快捷鍵進(jìn)行操作。

            Ctrl + Shift + F——源代碼格式

            Ctrl + Shift + O——組織輸入并刪除未使用的代碼

            代替手動調(diào)用這兩個函數(shù),只需根據(jù)Eclipse自動格式和自動組織選項,可以隨時保存文件。

            操作步驟,在Eclipse中進(jìn)入Window -> Preferences -> Java -> Editor -> Save Actions,然后以選定的方式保存,最后檢查Format source code + Organize imports。

            二、避免多個返回(退出點)

            依照你的方法,確保只有一個退出點。不要在同一個地方或多個地方使用返回。比如,下面的代碼,NOT RECOMMENDED(不建議),這是因為有多個退出點(返回語句)。

          1. private boolean isEligible(int age){  
          2.   if(age > 18){  
          3.     return true;  
          4.   }else{  
          5.     return false;  
          6.   }  
          7. }

            下面的代碼有所提升,這是更高版本的。

          1. private boolean isEligible(int age){  
          2.   boolean result;  
          3.   if(age > 18){  
          4.     result = true;  
          5.   }else{  
          6.     result = false;  
          7.   }  
          8.   return result;  
          9. }

            三、簡化if-else

            我寫了幾個實用的方法作為參考,檢查語句條件并且基于該條件返回值。比如,考慮到isEligible方法,正如你之前所看到的:

          1. private boolean isEligible(int age){  
          2.   boolean result;  
          3.   if(age > 18){  
          4.     result = true;  
          5.   }else{  
          6.     result = false;  
          7.   }  
          8.   return result;  
          9. }

            整個方法以一個單一的return語句重新編寫:

          1. private boolean isEligible(int age){  
          2. return age > 18;  
          3. }

            四、不要給Boolean, Integer或者String創(chuàng)建新的實例

            避免給Boolean,Integer,String創(chuàng)建新的實例。比如,使用new Boolean(true),Boolean,valueOf(true)。修改后的語句與之前的效果基本相同,除了在性能上有所提升。

            五、使用大括號模塊語句

            永遠(yuǎn)別忘了使用大括號模塊語句比如if、for、while。這樣做的好處是當(dāng)你在修改模塊級語句時減少了模糊代碼并且避免引進(jìn)bug的機(jī)會。

            不建議:

          1. if(age > 18)  
          2.   result = true;  
          3. else  
          4.   result = false;

            建議:

          1. if(age > 18){  
          2.   result = true;  
          3. }else{  
          4.   result = false;  
          5. }

           六、以final類型標(biāo)記方法參數(shù),任何時候都適用

            請記住,以final類型標(biāo)記方法參數(shù),任何時候都適用。這樣做的好處在于當(dāng)你不小心修改參數(shù)值時,編譯器會給你警告,同時它還能以更好的方式優(yōu)化編譯器代碼字節(jié)。

            建議:

          private boolean isEligible(final int age){ ... }

            七、在UPPERCASE中命名public static final字段

            在UPPERCASE中命名public static final字段(通常也被稱之為常量)。這個可以讓你輕松區(qū)分常量字段和局部變量之間的不同。

            不建議:

          public static final String testAccountNo = "12345678";

            建議:

          public static final String TEST_ACCOUNT_NO = "12345678";,

            八、組合成單一的if語句

            在盡可能多的情況下,把多個if語句組合成單一的if語句,比如下面的代碼:

          1. if(age > 18){  
          2.   if( voted == false){  
          3.     // eligible to vote.  
          4.   }  
          5. }

            合并成單一的if語句:

          1. if(age > 18 && !voted){  
          2.   // eligible to vote  
          3. }

            九、Switch應(yīng)該有default

            始終給Switch語句添加default。

            十、使用常量來避免重復(fù)定義相同的字符串值

            如果你在多個地方必須使用字符串,那么使用常量來避免重復(fù)定義擁有相同值的字符串。

            比如,看下面的代碼:

          1. private void someMethod(){  
          2.   logger.log("My Application" + e);  
          3.   ....  
          4.   ....  
          5.   logger.log("My Application" + f);  
          6. }

            string literal“我的應(yīng)用”可以作為常量并且能在代碼中使用。

          1. public static final String MY_APP = "My Application";  
          2.  
          3. private void someMethod(){  
          4.   logger.log(MY_APP + e);  
          5.   ....  
          6.   ....  
          7.   logger.log(MY_APP + f);  
          8. }

          posted on 2012-09-13 10:08 順其自然EVO 閱讀(175) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          <2012年9月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          30123456

          導(dǎo)航

          統(tǒng)計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 祁门县| 昂仁县| 渝北区| 绥滨县| 大庆市| 合阳县| 镇原县| 荣成市| 秦皇岛市| 和政县| 东阳市| 同心县| 广东省| 衢州市| 思南县| 苍南县| 定西市| 都兰县| 桃园市| 友谊县| 深州市| 屏南县| 红安县| 祁连县| 改则县| 新郑市| 英德市| 合江县| 奉新县| 余干县| 平罗县| 汝南县| 宁远县| 六枝特区| 修武县| 阳朔县| 拉萨市| 永丰县| 河津市| 高陵县| 敖汉旗|