zoukankan      html  css  js  c++  java
  • 简单工厂模式(simple factory pattern)

    简单工厂模式是由一个工厂对象来决定创建出哪一种产品类的实例(对象)。就是由一个工厂类依据传入的參数来决定须要创建哪一种产品的对象或实例。

    此模式主要涉及到工厂角色,抽象产品,详细产品三个角色

    工厂类(Creator),此模式的核心,含有与应用紧密相关的商业逻辑,

    抽象产品(Product),担任须要创建产品的父类,一般由一个java接口事抽象类来实现

    详细产品(Concrete Product)。须要创建的产品的实例

            源码例如以下:

    1:抽象产品

    public interface Fruit {
    
        void grow();
    
        void plant();
    }
    
    2:详细产品1

    public class Apple implements Fruit {
    
        public Apple() {
            System.out.println("Apple.Apple");
        }
    
        @Override
        public void grow() {
            System.out.println("Apple.grow");
        }
    
        @Override
        public void plant() {
            System.out.println("Apple.plant");
    
        }
    }

    3:详细产品2
    public class FruitGardener {
    
        public static Fruit factory(String which) {
            if (which.equalsIgnoreCase("apple")) {
                return new Apple();
            } else {
                return new StrawBerry();
            }
        }
    }
    
    4:核心工厂类

    public class StrawBerry implements Fruit {
    
        public StrawBerry() {
            System.out.println("StrawBerry.StrawBerry");
        }
    
        @Override
        public void grow() {
            System.out.println("StrawBerry.grow");
    
        }
    
        @Override
        public void plant() {
            System.out.println("StrawBerry.plant");
    
        }
    }
    
    5:測试类

    public class Tests {
    
        @Test
        public void testSimpleFactory() {
            FruitGardener.factory("APPLE");
            FruitGardener.factory("strawberry");
        }
    
    }


    6:測试结果为:

    Apple.Apple
    StrawBerry.StrawBerry
    
    Process finished with exit code 0


    7:说明,本项目是基于maven构建,測试框架是採用 JUnit

    <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.11</version>
            </dependency>
    8:后面会加入源码




  • 相关阅读:
    洛谷P1600 天天爱跑步——树上差分
    洛谷P1155 双栈排序——思路题
    洛谷P2827 蚯蚓——思路题
    bzoj2763 [JLOI2011]飞行路线——分层图
    洛谷P2831 愤怒的小鸟——贪心?状压DP
    洛谷P1514 引水入城——dfs
    bzoj1854 [Scoi2010]游戏——匈牙利算法
    hdu1814 Peaceful Commission——2-SAT
    浙江理工大学: 铺地砖(3922)
    最大素因子(快)
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5216789.html
Copyright © 2011-2022 走看看