乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      14 個寫 Java 的習慣

       昵稱10087950 2022-06-16 發(fā)布于江蘇

      來源丨java那些事

      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

      反例

      圖片

      正例

      圖片

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

      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<StringString> map = new HashMap<>();
              map.put("name""du");
              for (String key : map.keySet()) {
                  String value = map.get(key);
              }
       
              map.forEach((k, v) -> {
       
              });
       
              // 推薦
              for (Map.Entry<StringString> entry : map.entrySet()) {
       
              }
      optional 判空
      //獲取子目錄列表
      public List<CatalogueTreeNode> 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ù)進行傳遞使用

      注釋

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

      14、判斷元素是否存在

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

      ArrayList<String> 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<String> set = new HashSet<>();
       
      // 判斷a是否在set中
       
      int index = hash(a);
       
      return getNode(index) != null

      由此可見其復雜度為O1。

      -End-

        本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
        轉藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多