zoukankan      html  css  js  c++  java
  • Java设计模式(一)工厂模式

    一、场景描述

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

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

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

    如下图所示:

    二、示例代码

    仪器数据采集接口:

    package lims.designpatterndemo.factorydemo;
    
    public interface EquipmentDataCapture {
        public String capture(String filePath);
    }

    PDF文件数据采集类:

    package lims.designpatterndemo.factorydemo;
    
    public class PdfFileCapture implements EquipmentDataCapture{
    
        @Override
        public String capture(String filePath) {
            return "PDF file content";
        }
    }

    Excel文件数据采集类:

    package lims.designpatterndemo.factorydemo;
    
    public class ExcelFileCapture implements EquipmentDataCapture{
    
        @Override
        public String capture(String filePath) { 
            return "Excel File Content";
        }
    }

    工厂类:

    package lims.designpatterndemo.factorydemo;
    
    public class EquipmentDataCaptureFactory {
    
        public static EquipmentDataCapture getPdfFileCapture(){
            return new PdfFileCapture();
        }
        
        public static EquipmentDataCapture getExcelFileCapture(){
            return new ExcelFileCapture();
        }
    }

    调用示例:

    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);
        }
    }
  • 相关阅读:
    flutter-布局(水平和垂直)
    flutter-GridView(网格列表)
    flutter-ListView(列表组件)
    flutter-图片组件(Image)的使用
    flutter-container-容器
    flutter-hello flutter 并且修改字体
    nginx
    初步学习next.js-7-打包
    初步学习next.js-6-使用antd
    初步学习next.js-5-编写css样式和lazyloading
  • 原文地址:https://www.cnblogs.com/mahongbiao/p/8618970.html
Copyright © 2011-2022 走看看