<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

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

          共 2920字,需瀏覽 6分鐘

           ·

          2022-05-11 02:50

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

          1. 定義配置文件信息


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


          例如



          用 @ConfigurationProperties 代替 @Value


          使用方法


          定義對應(yīng)字段的實體


          @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 注入, 構(gòu)造器注入, 注解注入),Spring 推薦我們使用構(gòu)造器的方式注入 Bean,我們來看看上段代碼編譯完之后的樣子



          RequiredArgsConstructor:lombok提供


          3.代碼模塊化


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

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



          4. 拋異常而不是返回


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


          反例



          正例



          5. 減少不必要的db


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


          舉例子


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


          反例



          正例



          6. 不要返回 null


          反例



          正例



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


          7. if else


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


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


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


          反例



          正例



          9. 利用好Idea


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


          舉一個小例子


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


          例如



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



          10. 閱讀源碼


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


          11. 設(shè)計模式


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


          12. 擁抱新知識


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


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


          注釋


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


          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;


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


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


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


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

          (完)

          碼農(nóng)突圍資料鏈接

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

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

          瀏覽 42
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

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

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  国产视频黄色 | 视频一区 中文字幕 | www色老板 | 人人操,人人搞,人人摸 | 99久热手机视频免费观看 |