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 個(gè)寫好 Java 代的習(xí)慣

        共 3123字,需瀏覽 7分鐘

         ·

        2022-02-28 10:01

        1. 定義配置文件信息

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

        例如

        用 @ConfigurationProperties 代替 @Value

        使用方法

        定義對(duì)應(yīng)字段的實(shí)體

        @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;
        }

        使用時(shí)注入這個(gè)bean

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

        2. 用@RequiredArgsConstructor代替@Autowired

        我們都知道注入一個(gè) bean 有三種方式哦(set 注入, 構(gòu)造器注入, 注解注入),Spring 推薦我們使用構(gòu)造器的方式注入 Bean

        我們來看看上段代碼編譯完之后的樣子

        RequiredArgsConstructor:lombok提供

        3.代碼模塊化

        阿里巴巴 Java 開發(fā)手冊中說到每個(gè)方法的代碼不要超過 50 行(我沒記錯(cuò)的話),在實(shí)際的開發(fā)中我們要善于拆分自己的接口或方法, 做到一個(gè)方法只處理一種邏輯, 說不定以后某個(gè)功能就用到了, 拿來即用。

        4. 拋異常而不是返回

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

        反例

        正例

        5. 減少不必要的db

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

        舉例子

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

        反例

        正例

        6. 不要返回 null

        反例

        正例

        別處調(diào)用方法時(shí),避免不必要的空指針

        7. if else

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

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

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

        反例

        正例

        9. 利用好Idea

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

        舉一個(gè)小例子

        idea會(huì)對(duì)我們的代碼進(jìn)行判斷,提出合理的建議

        例如:

        它推薦我們用lanbda的形式代替,點(diǎn)擊replace

        10. 閱讀源碼

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

        11. 設(shè)計(jì)模式

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

        12. 擁抱新知識(shí)

        像我們這種工作年限少的程序員,我覺得要多學(xué)習(xí)自己認(rèn)知之外的知識(shí),不能每天crud,有機(jī)會(huì)就多用用有點(diǎn)難度的知識(shí),沒有機(jī)會(huì)(項(xiàng)目較傳統(tǒng)),可以自己下班多些相關(guān)demo練習(xí)

        13. 基礎(chǔ)問題

        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ù)量的遞歸時(shí),避免在遞歸方法里new對(duì)象,可以試試把對(duì)象當(dāng)作方法參數(shù)進(jìn)行傳遞使用

        注釋

        類 接口方法 注解 較復(fù)雜的方法 注釋都要寫而且要寫清楚, 有時(shí)候?qū)懽⑨尣皇墙o別人看的 而是給自己看的

        14. 判斷元素是否存在

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

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

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

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

        由此可見其復(fù)雜度為O1。

        地址:https://blog.csdn.net/weixin_44912855/article/details/120866194

        【END】

        如果看到這里,說明你喜歡這篇文章,請轉(zhuǎn)發(fā)、點(diǎn)贊

        技術(shù)交流群


        建了一個(gè)技術(shù)群,主要針對(duì)一些新的技術(shù)和開源項(xiàng)目值不值得去研究和IDEA使用的“騷操作”,有興趣入群的同學(xué),可以長掃描區(qū)域二維碼,一定要注意事項(xiàng):城市+昵稱+技術(shù)方向,根據(jù)格式備注,可快速通過。


        ▲長按掃描


        熱門推薦:

        瀏覽 24
        點(diǎn)贊
        評(píng)論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        評(píng)論
        圖片
        表情
        推薦
        點(diǎn)贊
        評(píng)論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        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>
            五月婷婷天堂 | 午夜高潮 | 黄片小视频插插插 | 婷婷激情视频网 | 人人插人人摸人人操 | 无毛一线逼 | 猫先生大连劲爆身材语文 | 大鸡巴插我 | 家庭乱伦一级视频 | 娇妻被邻居灌满精h陈楚 |