<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      工程實踐:如何給變量取一個好的名字

      工程實踐:如何給變量取一個好的名字

        在上一篇文章中跟大家分享了關于函數命名的一些實踐心得,今天我們繼續命名這個話題,來講一講如何對變量命名。

        以下是本文的目錄大綱:

        一. 變量命名風格

        二. 變量命名最高境界

        三. 變量命名最佳實踐

        若有不正之處請多多諒解,并歡迎批評指正。

        請尊重作者勞動成果,轉載請標明原文鏈接:

           http://www.rzrgm.cn/dolphin0520/p/10639167.html

       

      一.變量命名風格

        變量命名風格通常會根據不同的變量類型來區分,以Java語言為例,根據變量類型不同有兩種命名風格:

      1)類成員變量、局部變量

        類成員變量、局部變量通常采用駝峰命名風格,如下:

      String userName;

      2)靜態成員變量、枚舉值、常量

        靜態成員變量、枚舉值、常量通常采用所有字母大寫、多個單詞以英文下劃線連接,如:

      public static final int MAX_YEARS = 25;
      ?
      // 建議枚舉類都以Enum結尾
      enum ColorEnum {
          RED(0, "紅色"),
          YELLOW(1, "黃色"),
          GREEN(2, "綠色"),
          WHITE(3, "白色"),
          BLACK(4, "黑色");
          private int code;
          private String name;
      ?
          Color(int code, String name) {
              this.code = code;
              this.name = name;
          }
      }

      二.變量命名最高境界

        在函數命名那篇中我們說的函數命名最高境界是見字如面,那么對于變量命名來說,最高境界是什么呢? 我認為是:自解釋,即"代碼即注釋"。

        為什么這么說呢,因為通常來說一個函數是會有函數注釋的,即使函數名字取的不好,如果注釋寫的比較清楚,對于后續維護人員來說也是了解函數具體功能的一種方式。

        而變量則不同,在一個工程里面,變量的數量遠遠大于函數的數量,所以不太可能對于每個變量都去寫注釋,所以如果一個工程的變量命名很糟糕,那么對于后續維護人員來說將是毀滅性的打擊,因為每讀到一個變量,可能就需要去猜測變量的含義,我想沒有哪個人愿意讀到這樣的代碼,永遠記住一點:"代碼是寫給人看的,不是寫給機器看的"。

        譬如下面這段代碼的命名就非常糟糕:

      ppn = (cpn > 1) ? (cpn - 1) : cpn;
      npn = (cpn < tpn) ? (cpn + 1) : tpn;
      ?
      p = new Page(ppn, cpn, npn, tpn);

        上面這段代碼估計只有原作者清楚地知道各個變量的含義是啥了,

        如果修改為下面這種寫法,可讀性會好很多,并且一目了然,很容易知道其大概意圖是計算分頁信息:

      prePageNum = (curPageNum > 1) ? (curPageNum - 1) : curPageNum;
      nextPageNum = (curPageNum < totalPageNum) ? (curPageNum + 1) : totalPageNum;
      ?
      page = new Page(prePageNum, curPageNum, nextPageNum, totalPageNum);

      三.變量命名最佳實踐

      1)采用名詞或者形容詞來命名變量

        變量一般情況下建議使用名詞、名字組合或者形容詞,因為變量一般形容的是一種事物或者事物的屬性,所以用名詞或者名詞組合更容易讓人理解,而形容詞一般用于bool類型的變量。

      2)避免使用單字母變量,盡量細化變量含義

        在程序中,盡量避免使用單字母變量,唯一可以接受使用單字母變量的場景只有for循環,不過還是不太推薦在for循環中使用單字母變量(用pos、index比for循環的i、j、k要好很多)。

        舉個例子,比如下面這行代碼:

      double calConeVolume(double b, double d) {
        return Math.PI * b * b * d / 3;
      }
      

        咋一看這個函數參數感覺挺清晰,但是一細看,b是什么?d又是什么?如果我要用這個函數,該怎么傳參?估計大部人是一臉懵逼狀,只能進去看實際的函數實現才知道b是圓錐體半徑,d是圓錐體高度;

        那么怎么優化這段代碼命名呢?其實很簡單,稍微細化一下變量含義,讓變量名自己去表達實際意圖:

      double calConeVolume(double radius, double height) {
        return Math.PI * radius * radius * height / 3;
      }

      3)變量命名前后用詞需統一

        在同一個工程或者一個場景下,變量命名風格需前后統一,比如total和sum都能表示總計的意思,那么所有需要用到"總計"含義的地方要么全部使用total、要么全部使用sum。

        保持前后命名風格統一是保證工程代碼良好可讀性的關鍵保證。

      4)集合變量用類型或者復數s作為后綴

        在java中,有很多集合,比如List、Map、Set等,那么集合變量該怎么命名呢?

        一般可采取兩種方式:

      • 使用復數s結尾

      List<Student> students = new ArrayList<>();
      • 用集合類型作為后綴

      List<Student> studentList = new ArrayList<>();

        上面兩種方式均可,沒有比較明顯的偏好,根據實際場景決定。第一種方式相對更簡潔,第二種在局部作用域里面有多種相關的集合變量時區分度更大,比如:

      List<Student> studentList = new ArrayList<>();
      Map<Long, Student> studentMap = Maps.newHashMap();
      ?
      for (Student stu : studentList) {
        studentMap.put(stu.getId, stu);
      }
      

        我的建議是如果局部作用域只有一種類型的集合,那么推薦使用復數形式;如果局部作用域有多個相關的集合類型,那么推薦用類型結尾。

      5)禁止使用is作為bool類型的類成員變量前置

        在java中,禁止用is作為bool類型的類成員變量的前綴,因為is作為前綴會導致序列化/反序列出現問題,阿里的java代碼規范中也明確提到了這一點,所以在寫代碼的時候最好還是遵守公認的規范,不然哪天說不定就踩坑了。

      6)盡量避免使用縮寫進行命名

        有些時候,變量名可能有點長,不利于代碼可讀性,因此很多時候在寫代碼的時候喜歡用縮寫來命名,但這個不是一個好的習慣,除非使用的縮寫是大家都會使用的約定俗稱的縮寫。

        比如下面這個命名:

      int averageStudentAge;  =>  int avgStudentAge;

        因為avg大家都知道是average的縮寫,所以這么寫問題不大,不會引起歧義;

        但是下面這種縮寫命名:

      res
      tmp
      cnt

        就不是好的縮寫命名,因為不同的人閱讀可能會有不同的理解:

      res => response、resource、result
      tmp => temporary、template
      cnt => count、content、context

        附上一些約定俗稱的縮寫:

      全稱 縮寫
      identification id
      average avg
      maximum max
      minimum min
      buffer buf
      error err
      message msg
      image img
      length len
      library lib
      password pwd
      position pos
      data transfer object dto
      view object vo

       

      7)拋棄掉flag變量

        國內一些早期的教材上,到處充斥著各種flag風格的變量,這種命名方式對于大型工程簡直就是噩夢,比如:

      int flag = getDoctorFlag(doctorId);
      if (flag == 1) {
        //....
      }

        看到這段代碼,讀者會有疑問flag變量的含義是什么?flag值為1的時候又代表什么含義?是醫生的值班/在崗狀態、還是醫生的身體狀態?估計讀者的內心是崩潰的。

        如果優化成下面這種形式:

      DutyStatus doctorDutyStatus = getDoctorDutyStatus(doctorId);
      if (doctorDutyStatus == DutyStatus.ONLINE) {
        // ...
      }
      

        就比上面的形式清晰多了,很容易看出來判斷的是醫生的值班/在崗狀態。

      posted @ 2019-04-01 22:34  Matrix海子  閱讀(8016)  評論(10)    收藏  舉報
      主站蜘蛛池模板: 高潮喷水抽搐无码免费| 男女猛烈激情xx00免费视频| 亚洲一区二区av在线| 中文无码乱人伦中文视频在线| 欲香欲色天天天综合和网| 国产高清国产精品国产专区| 亚洲人成电影网站 久久影视| 国产精品久久国产精麻豆99网站| 性男女做视频观看网站| 2020久久国产综合精品swag| 欧美、另类亚洲日本一区二区| 国产日韩综合av在线| 在线免费观看视频1区| 久久精产国品一二三产品| 人妻精品动漫H无码中字| 国产精品天天看天天狠| 久久91精品牛牛| 亚洲午夜成人精品电影在线观看| 红原县| 精品无码三级在线观看视频| 免费无码黄十八禁网站| 中文文字幕文字幕亚洲色| 老熟女重囗味hdxx69| 欧美国产精品啪啪| 超碰国产天天做天天爽| 丰满人妻AV无码一区二区三区| 国产综合久久99久久| 国产亚洲一区二区三区四区| 国产乱码一区二区三区| 高中女无套中出17p| 国内自拍网红在线综合一区| 日韩人妻少妇一区二区三区| 精品国产成人国产在线视| 欧洲无码一区二区三区在线观看 | 精品午夜福利在线视在亚洲| 国产在线亚州精品内射| 久久99久国产麻精品66| 94人妻少妇偷人精品| 一本精品99久久精品77| 国产成人免费永久在线平台| 色综合色天天久久婷婷基地|