1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        14 個寫 Java 的好習慣!你做到了嗎?

        共 2920字,需瀏覽 6分鐘

         ·

        2022-05-11 02:50

        點擊上方“碼農突圍”,馬上關注
        這里是碼農充電第一站,回復“666”,獲取一份專屬大禮包
        真愛,請設置“星標”或點個“在看”

        1. 定義配置文件信息


        有時候我們?yōu)榱私y(tǒng)一管理會把一些變量放到 yml 配置文件中


        例如



        用 @ConfigurationProperties 代替 @Value


        使用方法


        定義對應字段的實體


        @Data
        // 指定前綴
        @ConfigurationProperties(prefix = "developer")
        @Component
        public class DeveloperProperty {
        ????private?String?name;
        ????private?String?website;
        ????private?String?qq;
        ????private?String?phoneNumber;
        }


        @Data
        // 指定前綴
        @ConfigurationProperties(prefix = "developer")
        @Component
        public class DeveloperProperty {
        ????private?String?name;
        ????private?String?website;
        ????private?String?qq;
        ????private?String?phoneNumber;
        }


        使用時注入這個bean


        @RestController
        @RequiredArgsConstructor
        public class PropertyController {
        ?
        ????final?DeveloperProperty?developerProperty;
        ?
        ????@GetMapping("/property")
        ????public?Object?index() {
        ???????return?developerProperty.getName();
        ????}
        }


        2. 用@RequiredArgsConstructor代替@Autowired


        我們都知道注入一個 bean 有三種方式哦(set 注入, 構造器注入, 注解注入),Spring 推薦我們使用構造器的方式注入 Bean,我們來看看上段代碼編譯完之后的樣子



        RequiredArgsConstructor:lombok提供


        3.代碼模塊化


        阿里巴巴 Java 開發(fā)手冊中說到每個方法的代碼不要超過 50 行(我沒記錯的話)

        ,在實際的開發(fā)中我們要善于拆分自己的接口或方法, 做到一個方法只處理一種邏輯, 說不定以后某個功能就用到了, 拿來即用。



        4. 拋異常而不是返回


        在寫業(yè)務代碼的時候,經(jīng)常會根據(jù)不同的結果返回不同的信息,盡量減少返回,會顯得代碼比較亂。


        反例



        正例



        5. 減少不必要的db


        盡可能的減少對數(shù)據(jù)庫的查詢


        舉例子


        刪除一個服務(已下架或未上架的才能刪除),之前有看別人寫的代碼,會先根據(jù)id查詢該記錄,然后做一些判斷。


        反例



        正例



        6. 不要返回 null


        反例



        正例



        別處調用方法時,避免不必要的空指針


        7. if else


        不要太多了if else if,可以試試策略模式代替


        8. 減少controller業(yè)務代碼


        業(yè)務代碼盡量放到service層進行處理,后期維護起來也好操作而且美觀。


        反例



        正例



        9. 利用好Idea


        目前為止市面上的企業(yè)基本都用idea作為開發(fā)工具了吧。


        舉一個小例子


        idea會對我們的代碼進行判斷,提出合理的建議


        例如



        它推薦我們用lanbda的形式代替,點擊replace



        10. 閱讀源碼


        一定要養(yǎng)成閱讀源碼的好習慣包括優(yōu)秀的開源項目GitHub上stars:>1000, 會從中學好好多知識包括其對代碼的設計思想以及高級API,面試加分(好多面試官習慣問源碼相關的知識)


        11. 設計模式


        23種設計模式,要嘗試代碼中運用設計模式思想,寫出的代碼即規(guī)范又美觀還高大上哈哈。


        12. 擁抱新知識


        像我們這種工作年限少的程序員,我覺得要多學習自己認知之外的知識,不能每天crud,有機會就多用用有點難度的知識,沒有機會(項目較傳統(tǒng)),可以自己下班多些相關demo練習


        13. 基礎問題


        map遍歷


        HashMap<String, String> map = new?HashMap<>();
        map.put("name", "du");
        for?(String?key : map.keySet()) {
        ????String?value = map.get(key);
        }

        map.forEach((k, v) -> {

        });

        // 推薦
        for?(Map.Entry<String, String> entry : map.entrySet()) {

        }


        optional 判空


        //獲取子目錄列表
        public?List getChild(String pid) {
        ????????????if?(V.isEmpty(pid)) {
        ????????????pid = BasicDic.TEMPORARY_DIRECTORY_ROOT;
        ????????}
        ????????CatalogueTreeNode node = treeNodeMap.get(pid);
        ?
        ????????return?Optional.ofNullable(node)
        ????????????????.map(CatalogueTreeNode::getChild)
        ????????????????.orElse(Collections.emptyList());
        ????}


        遞歸


        大數(shù)據(jù)量的遞歸時,避免在遞歸方法里new對象,可以試試把對象當作方法參數(shù)進行傳遞使用


        注釋


        類 接口方法 注解 較復雜的方法 注釋都要寫而且要寫清楚, 有時候寫注釋不是給別人看的 而是給自己看的


        14. 判斷元素是否存在


        hashSet 而不是 list,list 判斷一個元素是否存在的代碼


        ArrayList list?= new?ArrayList<>();
        ?
        // 判斷a是否在list中
        ?
        for?(int?i = 0; i < list.size(); i++)
        ???????if?("a".equals(elementData[i]))
        ??????????return?i;


        由此可見其復雜度為On,而hashSet底層采用hashMap作為數(shù)據(jù)結構進行存儲,元素都放到map的key(即鏈表中)


        HashSet set?= new?HashSet<>();
        // 判斷a是否在set中
        int?index = hash(a);
        return?getNode(index) != null


        由此可見其復雜度為O1。


        來源:blog.csdn.net/weixin_44912855/article/details/120866194

        (完)

        碼農突圍資料鏈接

        1、臥槽!字節(jié)跳動《算法中文手冊》火了,完整版 PDF 開放下載!
        2、計算機基礎知識總結與操作系統(tǒng) PDF 下載
        3、艾瑪,終于來了!《LeetCode Java版題解》.PDF
        4、Github 10K+,《LeetCode刷題C/C++版答案》出爐.PDF

        歡迎添加魚哥個人微信:smartfish2020,進粉絲群或圍觀朋友圈

        瀏覽 42
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            91黄色视频网站在线观看 | 噜噜av| 五月丁香深爱网 | 成人AV一区二区三区四区 | 操逼免费观看 | 午夜一级免费电影 | 波多野结衣在线视频免费观看 | 妞干网在线免费视频 | 亚洲性视频 | 国产亚非视频 |