Иногда я оставляю старый метод. Это бывает полезно, если это public метод и мне не хочется менять интерфейсы других классов.
Конечно осталось еще кое что, что мне хотелось бы сделать в Rental.getCharge(), но пока оставим его и вернемся к Customer.statement.
public String statement() { double totalAmount = 0; int frequentRenterPoints = 0; Enumeration rentals = this.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 frequentRenterPoints++; // add bonus for a two day new release rental if( each.getMovie().getPriceCode()==Movie.NEW_RELEASE && each.getDaysRented()>1) frequentRenterPoints++; // show figures for this rental result += "\t"+each.getMovie().getTitle()+"\t"+ String.valueOf( thisAmount)+"\n"; totalAmount += thisAmount; } // add footer lines result += "Amount owned is "+String.valueOf( totalAmount)+"\n"; result += "You earned "+String.valueOf( frequentRenterPoints)+ " frequent renter points"; return result; }
В начало | предыдущая | следующая