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

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

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

    ivaneeo's blog

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

      BlogJava :: 首頁(yè) :: 聯(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;
    }
    我喜歡盡量除去這一類(lèi)臨時(shí)變量.臨時(shí)變量往往形成問(wèn)題.它們會(huì)導(dǎo)致大量參數(shù)被傳來(lái)傳 去,而其實(shí)完全沒(méi)有這種必要.你很容易失去它們的蹤跡,尤其在長(zhǎng)長(zhǎng)的函數(shù)之中更是如此.當(dāng)然我這么做也需付出性能上的代價(jià),例如本例的費(fèi)用就被計(jì)算了兩 次.但是這很容易在Rental class中被優(yōu)化.而且如果代碼有合理的組織和管理,優(yōu)化會(huì)有很好的效果.
    posted on 2005-08-15 13:12 ivaneeo 閱讀(194) 評(píng)論(0)  編輯  收藏 所屬分類(lèi): refactoring-從地獄中重生
    主站蜘蛛池模板: 亚洲伊人久久大香线蕉综合图片 | 阿v免费在线观看| 亚洲黄色免费网址| 国产91精品一区二区麻豆亚洲| 三年片在线观看免费大全 | 亚洲国产精品不卡毛片a在线| 国产1024精品视频专区免费| 日本免费高清视频| 羞羞视频免费网站日本| 亚洲人成网亚洲欧洲无码| 亚洲国产成人手机在线电影bd| 亚洲成a人片在线观看日本| 亚洲国产一级在线观看| 国产一级理论免费版| 女人被男人躁的女爽免费视频| 国产乱子精品免费视观看片| 在线播放免费人成毛片乱码| 一个人看的免费观看日本视频www| 亚洲精品无播放器在线播放| 日韩在线视精品在亚洲| 亚洲国产精品久久网午夜| 久久亚洲春色中文字幕久久久| 亚洲乱码中文字幕久久孕妇黑人| 亚洲黄片毛片在线观看| 免费人成激情视频| 在线免费观看国产视频| 国产大片51精品免费观看| 在线观看免费a∨网站| 午夜免费福利网站| 午夜免费福利在线| 国产大片91精品免费看3| 国产成人免费a在线视频色戒| 日本最新免费不卡二区在线| 白白国产永久免费视频| 日本免费网站观看| 免费人成视频x8x8入口| 亚洲国产精品专区在线观看| 亚洲一区无码精品色| 亚洲另类激情综合偷自拍图| 亚洲国产精品成人久久| 97亚洲熟妇自偷自拍另类图片|