zoukankan      html  css  js  c++  java
  • 转--简单工厂模式 Simple Factory

    简单工厂模式的作用就是定义一个用于创建对象的接口

    在简单工厂模式中,一个工厂类处于对产品类实例化调用的中心位置上,它决定那一个产品类应当被实例化。

            先来看看它的组成:

             1) 工厂类角色:这是本模式的核心,含有一定的商业逻辑和判断逻辑。在java中它往往由一个具体类实现。

             2) 抽象产品角色:它一般是具体产品继承的父类或者实现的接口。在java中由接口或者抽象类来实现。

             3) 具体产品角色:工厂类所创建的对象就是此角色的实例。在java中由一个具体类实现。

    首先定义一个接口

    复制代码
    /**
     * @author ieasy360_1
     * 定义一个接口
     */
    public interface Sender{
        
        public void send();
    }
    复制代码

    创建类实现Sender接口

    复制代码
    public class Qq implements Sender{
    
        @Override
        public void send() {
            // TODO Auto-generated method stu
            System.out.println("this is qq send!"); 
        }
    }
    复制代码
    复制代码
    public class Weixin implements Sender {
    
        @Override
        public void send() {
            // TODO Auto-generated method stub
            System.out.println("this is Weixin send!"); 
        }
    }
    复制代码

    创建一个工厂类

    复制代码
    /**
     * @author ieasy360_1
     * 工厂类
     */
    public class SenderFactory {
    
        public Sender sendproduce(String type)
        {
            if(type.equals("qq"))
            {
                return new Qq();
            }
            else if(type.equals("wx"))
            {
                return new Weixin();
            }
            else
            {
                return null;
            }
        }
    }
    复制代码

    具体用法

    复制代码
    /**
     * @author ieasy360_1
     *
     */
    public class Test1 {
    
        /**
         * @param args
         */
        public static void main(String[] args) {
            // TODO Auto-generated method stub
    
            SenderFactory factory = new SenderFactory();
            Sender sender = factory.sendproduce("qq");
            sender.send();
        }
    }
    复制代码

    运行得到的结果

    this is qq send!
  • 相关阅读:
    关于ng路由的传参问题(传递一个,多个参数)
    ng指令控制一个元素的影藏的与显示几种方法的使用
    将一个对象push到数组之中的几点问题
    关于ng的路由的几点想法(ui-view)
    angularJS自定义一个过滤器
    ng自带的表单验证
    实现标签的添加与删除(tags)
    关于ng-class,ng-style的用法
    5分钟搞懂:session与cookie
    前端浏览器的两种缓存:协商缓存和强缓存
  • 原文地址:https://www.cnblogs.com/awkflf11/p/4370536.html
Copyright © 2011-2022 走看看