2015-05-05 11:20:13 -07:00

67 lines
1.6 KiB
Java

//: patterns/recycleb/RecycleB.java
// Adding more objects to the recycling problem.
package patterns.recycleb;
import patterns.trash.*;
import java.util.*;
// A vector that admits only the right type:
class Tbin extends ArrayList {
Class binType;
Tbin(Class binType) {
this.binType = binType;
}
boolean grab(Trash t) {
// Comparing class types:
if(t.getClass().equals(binType)) {
add(t);
return true; // Object grabbed
}
return false; // Object not grabbed
}
}
class TbinList extends ArrayList { //(*1*)
boolean sort(Trash t) {
Iterator e = iterator();
while(e.hasNext()) {
Tbin bin = (Tbin)e.next();
if(bin.grab(t)) return true;
}
return false; // bin not found for t
}
void sortBin(Tbin bin) { // (*2*)
Iterator e = bin.iterator();
while(e.hasNext())
if(!sort((Trash)e.next()))
System.out.println("Bin not found");
}
}
public class RecycleB {
static Tbin bin = new Tbin(Trash.class);
public static void main(String[] args) {
// Fill up the Trash bin:
ParseTrash.fillBin("Trash.dat", bin);
TbinList trashBins = new TbinList();
trashBins.add(
new Tbin(Aluminum.class));
trashBins.add(
new Tbin(Paper.class));
trashBins.add(
new Tbin(Glass.class));
// add one line here: (*3*)
trashBins.add(
new Tbin(Cardboard.class));
trashBins.sortBin(bin); // (*4*)
Iterator e = trashBins.iterator();
while(e.hasNext()) {
Tbin b = (Tbin)e.next();
Trash.sumValue(b);
}
Trash.sumValue(bin);
}
} ///:~