<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    ivaneeo's blog

    自由的力量,自由的生活。

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      669 Posts :: 0 Stories :: 64 Comments :: 0 Trackbacks
    實例代碼:
    public String statement() {
        double totalAmount = 0;
        int frequentRenterPoints = 0;
        Enumeration rentals = _rentals.elements();
        String result = "Rental Record for * " + getName() + "\n";
        while(rentals.hasMoreElements()) {
           double thisAmount = 0;
           Rental each = (Rental)rentals.nextElement();    //取得一筆租借記錄

           switch(each.getMovie().getPriceCode()) {   //取得影片出租價格
              case Movie.REGULAR:   //普通片
                 thisAmount += 2;
                 if(each.getDaysRented() > 2)
                    thisAmount += (each.getDaysRented() - 2) * 1.5;
                 break;
              case Movie.NEW_RELEASE:   //新片
                 thisAmount += each.getDaysRented() * 3;
                 break;
              case Movie.CHILDRENS:   //兒童片
                 thisAmount += 1.5;
                 if(each.getDaysRented() > 3)
                    thisAmount += (each.getDaysRented() - 3) * 1.5;
                 break;
           }

          
    //   add frequent renter points(累加常客積點)
              frequentRenterPoints ++;
              if((each.getMovie().getPriceCode() == Movie.NEW_RELEASE) &&
                 each.getDaysRented() > 1)
                 frequentRenterPoints ++;

              result += "\t" + each.getMovie().getTitle() + "\t" +
                 String.valueOf(thisAmount) + "\n";
              totalAmount += thisAmount;
        }

        //   add footer lines(結尾打印)
        result += "Amount owed is " + String.valueOf(totalAmount) + " \n";
        result += "You earned " + String.valueOf(frequentRenterPoints) +
           "frequent renter points";
        return result;
    }

    第一步驟是找出代碼的邏輯泥團并運用Extract Method(110).本例一個明顯的邏輯泥團就是switch語句,把它提煉(extract)到獨立函數中似乎比較好.

    首先我得在這段代碼里頭找出函數內的局部變量(local variables)和參數(parameters).我找到了兩個:each和thisAmount,前者并未被修改,后者會被修改.任何不會被修改的 變量都可以被我當成參數傳入新的函數,至于會被修改的變量就需格外小心.如果只有一個變量會被修改,我可以把它當作返回值.thisAmount是個臨時 變量,其值在每次循環起始處被設為0,并且在switch語句之前不會改變,所以我可以把新函數的返回值賦予它.

    public String statement() {
        double totalAmount = 0;
        int frequentRenterPoints = 0;
        Enumeration rentals = _rentals.elements();
        String result = "Rental Record for * " + getName() + "\n";
        while(rentals.hasMoreElements()) {
           double thisAmount = 0;
           Rental each = (Rental)rentals.nextElement();    //取得一筆租借記錄

           thisAmount = amountFor(each);

           //   add frequent renter points(累加常客積點)
              frequentRenterPoints ++;
              if((each.getMovie().getPriceCode() == Movie.NEW_RELEASE) &&
                 each.getDaysRented() > 1)
                 frequentRenterPoints ++;

              result += "\t" + each.getMovie().getTitle() + "\t" +
                 String.valueOf(thisAmount) + "\n";
              totalAmount += thisAmount;
        }
    //   add footer lines(結尾打印)
        result += "Amount owed is " + String.valueOf(totalAmount) + " \n";
        result += "You earned " + String.valueOf(frequentRenterPoints) +
           "frequent renter points";
        return result;
    }

    public double amountFor(Rental each) {
        double thisAmount = 0;
        switch(each.getMovie().getPriceCode()) {   //取得影片出租價格
              case Movie.REGULAR:   //普通片
                 thisAmount += 2;
                 if(each.getDaysRented() > 2)
                    thisAmount += (each.getDaysRented() - 2) * 1.5;
                 break;
              case Movie.NEW_RELEASE:   //新片
                 thisAmount += each.getDaysRented() * 3;
                 break;
              case Movie.CHILDRENS:   //兒童片
                 thisAmount += 1.5;
                 if(each.getDaysRented() > 3)
                    thisAmount += (each.getDaysRented() - 3) * 1.5;
                 break;
           }
        return thisAmount;
    }

    現在,已經把原本的函數分為兩塊,可以分別處理它們.我不喜歡amountFor()內的某些變量名稱,現在是修改它們的時候.
    下面是原本的代碼:
       public double amountFor(Rental each) {
        double thisAmount = 0;
        switch(each.getMovie().getPriceCode()) {   //取得影片出租價格
              case Movie.REGULAR:   //普通片
                 thisAmount += 2;
                 if(each.getDaysRented() > 2)
                    thisAmount += (each.getDaysRented() - 2) * 1.5;
                 break;
              case Movie.NEW_RELEASE:   //新片
                 thisAmount += each.getDaysRented() * 3;
                 break;
              case Movie.CHILDRENS:   //兒童片
                 thisAmount += 1.5;
                 if(each.getDaysRented() > 3)
                    thisAmount += (each.getDaysRented() - 3) * 1.5;
                 break;
           }
        return thisAmount;
    }

    下面是易名后的代碼:
    public double amountFor(Rental aRental) {
        double result = 0;
        switch(aRental.getMovie().getPriceCode()) {   //取得影片出租價格
              case Movie.REGULAR:   //普通片
                 result += 2;
                 if(aRental.getDaysRented() > 2)
                    result += (aRental.getDaysRented() - 2) * 1.5;
                 break;
              case Movie.NEW_RELEASE:   //新片
                 result += aRental.getDaysRented() * 3;
                 break;
              case Movie.CHILDRENS:   //兒童片
                 result += 1.5;
                 if(aRental.getDaysRented() > 3)
                    result += (aRental.getDaysRented() - 3) * 1.5;
                 break;
           }
        return result;
    }
    posted on 2005-08-15 10:15 ivaneeo 閱讀(415) 評論(0)  編輯  收藏 所屬分類: refactoring-從地獄中重生
    主站蜘蛛池模板: 国产亚洲av人片在线观看| 日韩免费无码一区二区视频| 曰韩亚洲av人人夜夜澡人人爽 | 亚洲天然素人无码专区| 亚洲一级毛片免费观看| 亚洲免费网站在线观看| 日韩吃奶摸下AA片免费观看| 国产亚洲国产bv网站在线| 18国产精品白浆在线观看免费| 亚洲综合久久一本伊伊区| 四虎在线视频免费观看| 欧美日韩亚洲精品| 免费大黄网站在线观看| WWW免费视频在线观看播放| 亚洲AV成人片色在线观看高潮| 免费无码一区二区三区 | 欧洲亚洲综合一区二区三区 | 亚洲一区二区三区影院 | 日韩在线免费看网站| 老司机福利在线免费观看| 中文字幕亚洲综合久久男男| 中文字幕免费在线看| 久久精品国产亚洲AV电影| 国产免费av片在线看| 野花视频在线官网免费1| 亚洲午夜未满十八勿入网站2| 三年片在线观看免费观看大全一 | A级毛片高清免费视频在线播放| 亚洲欧洲精品视频在线观看| 永久免费av无码网站大全| 久久九九久精品国产免费直播 | 亚洲精品欧美综合四区| 亚洲毛片av日韩av无码| 最近中文字幕完整免费视频ww| 亚洲成年网站在线观看| 国产精品亚洲玖玖玖在线观看 | 亚洲性色AV日韩在线观看| 在线精品亚洲一区二区三区| 曰批全过程免费视频播放网站| 亚洲国产精品自在自线观看| 国产精品亚洲一区二区三区在线|