千里之行始于足下

          行運流水,做一個有趣的人.

             :: 首頁 :: 聯系 ::  :: 管理
          最近兩天閑下來了.心情有些不好.感覺現在跟當時所謂的理想越走越遠.

          千里之行始于足下,那就從現在開始吧.

          今天看了一些commons-lang3-3.1的代碼.正好最近在看<<代碼大全>>,就總結一下吧.

          拿org.apache.commons.lang3.ArrayUtils來說事吧.方法里面每個方法代碼都不多,代碼本身功能不復雜是一方面.防御式編程方面做的好,很多情況都考濾到了.

          但也有些地方不明白如:
           1     // Character array converters
           2     // ----------------------------------------------------------------------
           3     /**
           4      * <p>Converts an array of object Characters to primitives.</p>
           5      *
           6      * <p>This method returns {@code null} for a {@code null} input array.</p>
           7      *
           8      * @param array  a {@code Character} array, may be {@code null}
           9      * @return a {@code char} array, {@code null} if null array input
          10      * @throws NullPointerException if array content is {@code null}
          11      */
          12     public static char[] toPrimitive(Character[] array) {
          13         if (array == null) {
          14             return null;
          15         } else if (array.length == 0) {
          16             return EMPTY_CHAR_ARRAY;
          17         }
          18         final char[] result = new char[array.length];
          19         for (int i = 0; i < array.length; i++) {
          20             result[i] = array[i].charValue();
          21         }
          22         return result;
          23     }
          代碼里面如果換了我,一定會在第20行加一個非空判斷,但這里沒有.也許別人認為這是錯誤的情況另一個方法"char[] org.apache.commons.lang3.ArrayUtils.toPrimitive(Character[] array, char valueForNull)"可以完美的替換它吧.但總覺得應該加個非空判斷上去要好一些.
          posted on 2012-08-30 18:11 胖子胖子 閱讀(95) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 安乡县| 巩留县| 治县。| 理塘县| 乳山市| 东平县| 德令哈市| 合阳县| 巴林右旗| 芦溪县| 武平县| 青海省| 大新县| 桂林市| 云浮市| 中卫市| 八宿县| 阿克陶县| 峨边| 循化| 依安县| 马鞍山市| 泌阳县| 凤城市| 北辰区| 丽江市| 咸宁市| 石楼县| 察哈| 淅川县| 文水县| 苍梧县| 元江| 高要市| 海伦市| 叙永县| 湾仔区| 兴安盟| 黄冈市| 宜州市| 保山市|