zoukankan      html  css  js  c++  java
  • 设计模式:工厂方法模式

    简单工厂模式是由一个工厂对象决定创建出哪一种产品为的实例。(定义一个创建对象的类,由这个类来封装实例化对象的行为)

    在软件开发中,当我们会用到大量的创建某种、某类或某批对象时,就会用到工厂模式。

    工厂模式的意图:

    定义一个创建对象的接口,让其子类自己决定实例化哪一个工厂类,工厂模式使其创建过程延迟到子类进行。

    主要解决:

    接口的选择问题

    优点:

    1、一个调用者想创建一个对象,只要知道其名称就可以了。

    2、扩展性高,如果想增加一个产品,只要扩展一个工厂类就可以

    3、屏蔽产品的具体实现,调用者只关心产品的接口。

    缺点:

    1、每次增加一个产品时,都需要增加一个具体类的对象实现工厂,使得系统中类的个数成倍增加,在一定程度上增加了系统的复杂度,同时也增加了系统具体类的依赖。

    工厂方法模式分为三种:

    1、普通工厂模式

     共同接口:

    public interface Sender {
        public void send();
    }

    实现类:

    public class MailSender implements Sender{
    
        @Override
        public void send() {
            System.out.println("this is mailsender...");
        }
    }
    public class SmsSender implements Sender{
    
        @Override
        public void send() {
            System.out.println("this is sms sender...");
        }
    }

    工厂类:

    public class SendFactory {
        public Sender produce(String type){
            if("mail".equals(type)){
                return new MailSender();
            }else if ("sms".equals(type)){
                return new SmsSender();
            }else{
                System.out.println("type error!!");
                return null;
            }
        }
    }

    2、多个工厂方法模式

    工厂类

    public class SendFactory {
        
        public Sender produceMail(){
            return new MailSender();
        }
        
        public Sender produceSms(){
            return new SmsSender();
        }
    }

    3、静态工厂方法模式

    public class SendFactory {
        public static Sender produceMail(){
            return new MailSender();
        }
        
        public static Sender produceSms(){
            return new SmsSender();
        }
    }

    还有一种

    public class SendFactory {
        
        public static Sender produce(String type) throws ClassNotFoundException, InstantiationException, IllegalAccessException{
            Class sender = Class.forName(type);
            return (Sender)sender.newInstance();
        }
    }

    mainTest

    package com.sheji.factorymethod;
    
    public class FactoryTest {
        public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
    //        SendFactory factory = new SendFactory();
    //        Sender sender = factory.produce("sms");
    //        sender.send();
            
    //        Sender sender1 = factory.produceMail();
    //        sender1.send();
            
            Sender sender2 = SendFactory.produceMail();
            sender2.send();
            
            Sender sender3 = SendFactory.produce("com.sheji.factorymethod.SmsSender");
            sender3.send();
        }
    }

    下面介绍一下简单工厂模式中的角色与职责

      简单工厂模式中包含的角色及其职责

       1、工厂(Creater)角色

        简单工厂模式的核心,它负责实现创建所有实例的内部逻辑。工厂类可以被外界直接调用,创建所需的产品对象。(SendFactory类)

       2、抽象(Product)角色

        简单工厂模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。(Sender接口)

       3、具体产品(Concrete Product)角色

        简单工厂模式所创建的具体实例对象。(MailSender类与SmsSender类)

      简单设计模式的优缺点:

    • 优点:简单工厂模式中,工厂类是整个模式的关键所在。它包含必要的判断逻辑,能够根据外界给定的信息,决定究竟应该创建哪个具体类的对象。用户在创建时可以直接使用工厂类去创建所需的实例,而无需去了解这些对象是如何创建以及如何组织的,明确区分了各自的职责和权力,有利于整个软件体系结构的优化。
    • 缺点:很明显简单工厂模式的缺点也体现在其工厂类上,由于工厂类集中了所有实例的创建逻辑,容易违反GRASPR的高内聚的责任分配原则,另外,当系统中的具体产品类不断增多时,可能会出现要求更改相应工厂类的情况,拓展性并不是很好。

      

      使用场景

       1、工厂类负责创建的对象比较少;
       2、客户只知道传入工厂类的参数,对于如何创建对象(逻辑)不关心;
       3、由于简单工厂很容易违反高内聚责任分配原则,因此一般只在很简单的情况下应用。
     
     
    应用
    JDK中的Calendar
  • 相关阅读:
    django 单表操作
    爬虫学习
    DRF源码分析
    DRF权限和频率限制
    DRF版本和认证源码分析
    request高级部分
    多任务异步爬虫及selenium模块使用
    requests基本使用
    爬虫介绍及环境
    Flask生命周期的源码流程
  • 原文地址:https://www.cnblogs.com/lisen10/p/11274963.html
Copyright © 2011-2022 走看看