先摘录Factory.java和RegisteredFactories.java的部分代码(虚线分隔):
package typeinfo.factory;
public interface Factory<T> {
T create();
}
// ---------------------------------------------------------
class Part {
public String toString() {
return getClass().getSimpleName();
}
static List<Factory<? extends Part>> partFactories =
new ArrayList<Factory<? extends Part>>();
static {
// Collections.addAll() gives an "unchecked generic
// array creation ... for varargs parameter" warning.
partFactories.add(new FuelFilter.Factory());
partFactories.add(new AirFilter.Factory());
partFactories.add(new CabinAirFilter.Factory());
partFactories.add(new OilFilter.Factory());
partFactories.add(new FanBelt.Factory());
partFactories.add(new PowerSteeringBelt.Factory());
partFactories.add(new GeneratorBelt.Factory());
}
private static Random rand = new Random(47);
public static Part createRandom() {
int n = rand.nextInt(partFactories.size());
return partFactories.get(n).create();
}
}
class Filter extends Part {}
class FuelFilter extends Filter {
// Create a Class Factory for each specific type:
public static class Factory implements typeinfo.factory.Factory<FuelFilter> {
public FuelFilter create() {
return new FuelFilter();
}
}
}
public class RegisteredFactories {
public static void main(String[] args) {
for (int i = 0; i < 10 ; i++ ) {
System.out.println(Part.createRandom());
}
}
基类Part保存的是它所有继承类的内部工厂类的列表。在执行
partFactories.add(new FuelFilter.Factory());
时,FuelFilter对象还未创建。因为在第10章 内部类 第三节 使用.this与.new中有这句话:
在拥有外部类对象之前是不可能创建内部类对象的。这是因为内部类对象会暗暗地连接到创建它的外部类对象中。但是,如果你创建的是嵌套类(静态内部类),那么它就不需要对外部类对象的引用。
而我们从FuelFilter类的代码中看到,它的内部类Factory确实是静态的!因而,并且内部类Factory的create()方法提供了统一的创建各继承类对象的方式。
这样,当我们扩大继承结构时,只需要在基类Part的工厂List中添加新的子类的内部Factory类就可以了。