对第14章类型信息中RegisteredFactories.java的理解

来源:互联网 发布:淘宝卖家开通公益宝贝 编辑:程序博客网 时间:2024/06/04 20:02

先摘录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类就可以了。

0 0
原创粉丝点击