前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java设计模式(一)工厂模式

Java设计模式(一)工厂模式

作者头像
用户1637609
发布2018-04-12 15:33:26
7530
发布2018-04-12 15:33:26
举报
文章被收录于专栏:马洪彪马洪彪

一、场景描述

仪器数据文件的格式包含Pdf、Word、Excel等多种,不同种格式的文件其数据的采集方式不同,因此定义仪器数据采集接口,并定义PDF、Excel等不同的数据采集类实现该接口。

通过工厂类,调用不同的方法,获取不同的仪器数据采集类,调用接口方法即可。

如不使用工厂模式,则需要new不同的采集类对象,使用工厂模式则隐藏了new的创建方式。

如下图所示:

二、示例代码

仪器数据采集接口:

代码语言:javascript
复制
package lims.designpatterndemo.factorydemo;

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

PDF文件数据采集类:

代码语言:javascript
复制
package lims.designpatterndemo.factorydemo;

public class PdfFileCapture implements EquipmentDataCapture{

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

Excel文件数据采集类:

代码语言:javascript
复制
package lims.designpatterndemo.factorydemo;

public class ExcelFileCapture implements EquipmentDataCapture{

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

工厂类:

代码语言:javascript
复制
package lims.designpatterndemo.factorydemo;

public class EquipmentDataCaptureFactory {

    public static EquipmentDataCapture getPdfFileCapture(){
        return new PdfFileCapture();
    }
    
    public static EquipmentDataCapture getExcelFileCapture(){
        return new ExcelFileCapture();
    }
}

调用示例:

代码语言:javascript
复制
package lims.designpatterndemo.factorydemo;

public class FactoryDemo { 

    public static void main(String[] args) {
        EquipmentDataCapture edc = EquipmentDataCaptureFactory.getPdfFileCapture();
        edc = EquipmentDataCaptureFactory.getExcelFileCapture();
        String fileContent = edc.capture("");
        System.out.println(fileContent);
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-03-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、场景描述
  • 二、示例代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档