67 lines
1.6 KiB
Java
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);
|
||
|
}
|
||
|
} ///:~
|