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

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

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

    ivaneeo's blog

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

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      669 Posts :: 0 Stories :: 64 Comments :: 0 Trackbacks
    Customer.statement():
    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 = each.getCharge();

           //   add frequent renter points(累加常客積點(diǎn))
              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(結(jié)尾打印)
        result += "Amount owed is " + String.valueOf(totalAmount) + " \n";
        result += "You earned " + String.valueOf(frequentRenterPoints) +
           "frequent renter points";
        return result;
    }

    下一件引我注意的事時(shí):thisAmount如今變成多余了.它接受each.getCharge()的執(zhí)行結(jié)果,然后就不再有任何改變.所以我可以運(yùn)用Replace Temp with Query(120)把thisAmount除去:
    public String statement() {
        double totalAmount = 0;
        int frequentRenterPoints = 0;
        Enumeration rentals = _rentals.elements();
        String result = "Rental Record for * " + getName() + "\n";
        while(rentals.hasMoreElements()) {
           Rental each = (Rental)rentals.nextElement();    //取得一筆租借記錄

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

              result += "\t" + each.getMovie().getTitle() + "\t" +
                 String.valueOf(each.getCharge()) + "\n";
              totalAmount += each.getCharge();
        }
    //   add footer lines(結(jié)尾打印)
        result += "Amount owed is " + String.valueOf(totalAmount) + " \n";
        result += "You earned " + String.valueOf(frequentRenterPoints) +
           "frequent renter points";
        return result;
    }
    我喜歡盡量除去這一類臨時(shí)變量.臨時(shí)變量往往形成問題.它們會(huì)導(dǎo)致大量參數(shù)被傳來傳 去,而其實(shí)完全沒有這種必要.你很容易失去它們的蹤跡,尤其在長長的函數(shù)之中更是如此.當(dāng)然我這么做也需付出性能上的代價(jià),例如本例的費(fèi)用就被計(jì)算了兩 次.但是這很容易在Rental class中被優(yōu)化.而且如果代碼有合理的組織和管理,優(yōu)化會(huì)有很好的效果.
    posted on 2005-08-15 13:12 ivaneeo 閱讀(189) 評(píng)論(0)  編輯  收藏 所屬分類: refactoring-從地獄中重生
    主站蜘蛛池模板: 久久精品国产亚洲AV网站| 亚洲系列国产精品制服丝袜第| 亚洲天堂2016| 国色精品va在线观看免费视频| 免费高清在线爱做视频| 亚洲综合成人网在线观看| 黄色a级免费网站| 国产精品视频免费一区二区| 久久精品亚洲综合| 亚洲爆乳成av人在线视菜奈实| 99久久99热精品免费观看国产| 亚洲一区二区免费视频| 免费又黄又爽的视频| 亚洲日韩精品一区二区三区无码 | 四虎永久成人免费影院域名| 亚洲精品综合久久中文字幕| 久久国产福利免费| 免费一级大黄特色大片| 亚洲日韩国产一区二区三区在线| 一区二区三区四区免费视频| 亚洲午夜久久久久久久久久| 免费亚洲视频在线观看| 青春禁区视频在线观看直播免费| 亚洲人成电影福利在线播放 | 二级毛片免费观看全程| 国产精品美女自在线观看免费| 亚洲福利视频网站| 久操免费在线观看| 亚洲人成人77777网站| 一级免费黄色毛片| 国产青草视频在线观看免费影院| 亚洲va在线va天堂成人| 亚洲香蕉免费有线视频| 亚洲av午夜成人片精品网站| 久久久久久噜噜精品免费直播| 亚洲国产日韩成人综合天堂| 国产精品亚洲色图| 四虎永久免费影院| 日本系列1页亚洲系列| 成人免费无码精品国产电影| 亚洲AV无码国产精品永久一区|