Java设计模式(二)抽象工厂模式

一、场景描述

接《Java设计模式(一)工厂模式》https://www.cnblogs.com/mahongbiao/p/8618970.html

工厂模式有一缺点,就是破坏了类的封闭性原则。例如,如果需要增加Word文件的数据采集,此时按以下步骤操作:

  1. 创建Word文件数据采集类,实现仪器数据采集接口;
  2. 修改仪器数据采集工厂类,增加Word文件数据采集类的工厂方法;
  3. 调用工厂类的word文件方法;

步骤2修改了工厂类,如果每增加一实现类都需要修改工厂类,那么这样就不合理了。

解决办法是使用抽象工厂类,为每一个实现类都创建其工厂类,并增加工厂接口,使各工厂类实现该接口。

使用抽象工厂后,上述步骤更改为:

  1. 创建Word文件数据采集类,实现仪器数据采集接口;
  2. 创建Word文件数据采集类的工厂类,该类实现工厂接口,接口方法创建Word文件数据采集类;
  3. 获取Word文件数据采集类的工厂类对象,并调用工厂接口方法,创建类对象,然后调用其方法。

修改后,由于对工厂类进行了抽象,定义了工厂接口,因此新增实现类时不再需要修改原有代码,不破坏原有实现。

如下图所示:

 

二、示例代码

仪器数据采集接口:

package lims.designpatterndemo.abstractfactorydemo;

public interface EquipmentDataCapture {
    public String capture(String filePath);
}

PDF文件采集类:

package lims.designpatterndemo.abstractfactorydemo;

public class PdfFileCapture implements EquipmentDataCapture{

    @Override
    public String capture(String filePath) {
        return "PDF file content";
    }
}

Excel文件采集类:

package lims.designpatterndemo.abstractfactorydemo;

public class ExcelFileCapture implements EquipmentDataCapture{

    @Override
    public String capture(String filePath) { 
        return "Excel File Content";
    }
}

抽象工厂,即工厂接口:

package lims.designpatterndemo.abstractfactorydemo;

public interface EquipmentDataCaptureFactory {
     public EquipmentDataCapture getCapture();  
}

PDF文件采集工厂类:

package lims.designpatterndemo.abstractfactorydemo;

public class PdfFileCaptureFactory implements EquipmentDataCaptureFactory {

    @Override
    public EquipmentDataCapture getCapture() { 
        return new PdfFileCapture();
    }
}

Excel文件采集工厂类:

package lims.designpatterndemo.abstractfactorydemo;

public class ExcelFileCaptureFactory implements EquipmentDataCaptureFactory {

    @Override
    public EquipmentDataCapture getCapture() {
        return new ExcelFileCapture();
    }
}

调用示例:

package lims.designpatterndemo.abstractfactorydemo;

public class AbstractFactoryDemo {
 
    public static void main(String[] args) {
        EquipmentDataCaptureFactory facotry = new PdfFileCaptureFactory();
        facotry = new ExcelFileCaptureFactory();
        EquipmentDataCapture capture = facotry.getCapture();
        String fileContent = capture.capture("");
        System.out.println(fileContent);
    }
}

 

posted @ 2018-03-21 19:20  马洪彪  阅读(175)  评论(0编辑  收藏  举报