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

    普通工厂模式

    只有一个工厂方法

    public interface Sender {
    	public void Send();
    }
    
    public class MailSender implements Sender {
    
    	@Override
    	public void Send() {
    		System.out.println("this is mail sender!");
    	}
    }
    
    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("请输入正确的类型!");
    			return null;
    		}
    	}
    }
    
    

    多个工厂方法

    public class SendFactory {
    	public Sender produceMail() {
    		return new MailSender(); 
    	}
    
    	public Sender produceSms() {
    		return new SmsSender();
    	}
    }
    
    public class FactoryTest {
    	public static void main(String[] args) {
    		SendFactory factory = new SendFactory();
    		Sender sender = factory.produceMail();
    		sender.send();
    	}
    }
    

    静态工厂模式

    把多个工厂方法设置为静态,不用创建工厂类就能生产

    抽象工厂模式

    工厂方法模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则,所以,从设计角度考虑,有一定的问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这样一旦需要增加新的功能, 直接增加新的工厂类就可以了,不需要修改之前的代码。

    // 定义接口的意义是生产对象时使用接口声明就可以了
    public interface Provider { // 工厂类接口
    public Sender produce();
    }-------------------------------------------------------------------------------------
    
    public interface Sender { // 生产对象接口
    public void send();
    }-------------------------------------------------------------------------------------
    
    public class MailSender implements Sender {
    
    	@Override
     public void send() {
     System.out.println("this is mail sender!");
     }
    }-------------------------------------------------------------------------------------
    
    public class SmsSender implements Sender {
    	@Override
     public void send() {
     System.out.println("this is sms sender!");
     }
    }-------------------------------------------------------------------------------------
    
    public class SendSmsFactory implements Provider {
    
    	@Override
     public Sender produce() {
     return new SmsSender();
     }
    }
    
    public class SendMailFactory implements Provider {
    
    @Override
    public Sender produce() {
    return new MailSender();
    }
    }-------------------------------------------------------------------------------------
    
    public class Test {
    	public static void main(String[] args) {
     Provider provider = new SendMailFactory(); // 直接使用接口定义
     Sender sender = provider.produce();
     sender.send();
     }
    }
    
  • 相关阅读:
    进程DLL注入
    静态链接库LIB
    利用MoveFileEx实现程序的隐藏、自启动与自删除
    QueueUserApc实现DLL注入的测试
    简单说说SSDT
    ural 1521. War Games 2 约瑟夫环 SBT实现
    次小生成树 (附:poj1679)
    hoj 1138 LC Display
    hoj 3029 Dictionary 模拟队列
    hoj 2578 Super_Stack 模拟栈
  • 原文地址:https://www.cnblogs.com/zhz-8919/p/10855612.html
Copyright © 2011-2022 走看看