23中设计模式----------工厂模式.

女娲造人故事开头(借由设计模式之禅):

  第一次烤泥人,感觉应该熟了,往大地一放,哇,没烤熟!于是白人诞生了!(这也是缺乏经验的最好证明)

  第二次烤泥人,上一次没烤熟,这一次多烤一会,放到世间一看,嘿,烤过头了,于是黑人诞生了!

  第三次烤泥人,一边烤一边察看,直到表皮嫩黄,嘿,真正好,于是黄色人种出现了!



言归正传,所谓的工厂模式,要从工厂说起,工厂就是制造生产东西的,所以,也很容易知道工厂模式就是,利用工厂生产对象。所以,工厂模式,要有工厂和需要生产的产品。

工厂模式的好处就在于,不需要知道对象是怎么产生的,只需要通过工厂我们可以根据不同的要求得到对应的对象。这样,既体现了封装,也表现了堕胎性。

由于需要生产具体的东西并不是很确定,所以产品一般都会是抽象类。

抽象产品代码:

//总球类
public abstract class Ball {
    public void fun1(){

    }
    public abstract void fun2();
}

然后,只需让具体的产品集成该抽象类(所以一个工厂基本是生产一类产品)。

//足球
public class Football extends Ball {

    public void fun2() {

    }
}
//篮球
public class Basketball extends Ball {

    public void fun2() {

    }
}

抽象工厂类定义产品生产方法:

1 //抽象工厂
2 public abstract class Factory {
3
4     public abstract <T extends Ball> T createBall(Class<T> c);
5
6 }

是生产哪种具体球,具体的工厂类实现来确定。

 1 public class BallFactory extends Factory {
 2     @Override
 3     public <T extends Ball> T createBall(Class<T> c) {
 4         Ball ball = null;
 5         try {
 6             ball = (Ball) Class.forName(c.getName()).newInstance();
 7         }  catch (Exception e) {
 8             e.printStackTrace();
 9         }
10
11         return (T) ball;
12     }
13 }

具体生产出的球类:

1 public class Client {
2     public static void main(String[] args) {
3         Factory factory = new BallFactory();
4                 //通过工厂生产出的足球类!
5         Ball footBall = factory.createBall(Football.class);
6     }
7 }    

这种简单的工厂模式,就设计好了。!



单例工厂模式:

 1 //单例类
 2 public class Singleton {
 3     private Singleton(){
 4
 5     }
 6 }
 7
 8 //单例工厂
 9 public class SingletonFactory {
10     private static Singleton single;
11     //生成实力
12     static{
13         try {
14             Class<?> clazz = Class.forName(Singleton.class.getName());
15             Constructor<?> constructor = clazz.getDeclaredConstructor();
16             constructor.setAccessible(true);
17             single = (Singleton) constructor.newInstance();
18         } catch (Exception e) {
19             e.printStackTrace();
20         }
21     }
22     //获取示例的方法
23     public static Singleton getInstance(){
24         return single;
25     }
26 }

在项目中,其实我们就有用到很多工厂模式,比如spring中的BeanFactory,我们通过spring容器帮我们创建我们所需要的实例对象,并不需要知道创建过程,并且维护该对象的生命周期也是通过spring,这样,封装性更好,同时扩展性也大大增强,更加安全!

时间: 2024-10-12 16:17:51

23中设计模式----------工厂模式.的相关文章

23种设计模式--工厂模式-Factory Pattern

一.工厂模式的介绍       工厂模式让我们相到的就是工厂,那么生活中的工厂是生产产品的,在代码中的工厂是生产实例的,在直白一点就是生产实例的类,代码中我们常用new关键字,那么这个new出来的实例就就依赖与这个类,2者之间的耦合度就高,此时我们就可以使用面向对象的去解决这个问题,将变化点封装起来,这就是我们将要首先引入的简单工厂模式:先来说一个场景,比如我们吃水果这个例子吧,我们有时候想吃苹果,有时候想吃橘子,但是每次都需要去买这些水果,后来有个水果店,又卖橘子,又卖苹果,这个水果店就当于简

开发模式-工厂模式

1.设计模式是前人根据经验总结出来的,使用设计模式,就相当于是站在了前人的肩膀上. 2.设计模式使程序易读.熟悉设计模式的人应该能够很容易读懂运用设计模式编写的程序. 3.设计模式能使编写的程序具有良好的可扩展性,满足系统设计的开闭原则.比如策略模式,就是将不同的算法封装在子类中,在需要添加新的算法时,只需添加新的子类,实现规定的接口,即可在不改变现有系统源码的情况下加入新的系统行为. 4.设计模式能降低系统中类与类之间的耦合度.比如工厂模式,使依赖类只需知道被依赖类所实现的接口或继承的抽象类,

.Net简单工厂模式,工厂模式,抽象工厂模式实例

1.定义   简单工厂模式:是由一个工厂对象决定创建出哪一种产品类的实例.简单工厂模式是工厂模式家族中最简单实用的模式,可以理解为是不同工厂模式的一个特殊实现. 工厂模式:定义一个用于创建对象的接口,让子类决定实例化哪一个类. 抽象工厂模式:为创建一组相关或相互依赖的对象提供一个接口,而且无需指定他们的具体类. 2.实例 用工人种蔬菜的例子来说明,蔬菜植物的产品器官有根.茎.叶.花.果等5类,因此按产品器官分类也分成5种,分别是根菜类,茎菜类,叶莱类,花菜类以及果菜类.我们以根菜类,茎菜类为例,

简单工厂模式 工厂模式 抽象工厂模式

其实这个三个C++的设计模式已经学习很长时间了,今晚才想起来要写这三个设计模式,为什么要用C++中的设计模式呢?for example,你已经会开车了,正着开,倒着开,转弯,这些都是开车基本的,但是你并没有很高的车技,并不会炫酷.漂移,就好像C++中的设计模式一样,在你学好C++的基础上,娴熟的应用出的新技能,能让你的车开的更好. 为什么要用简单工厂模式,记得上一次,我虽然敲完了代码,但是当别人突然问一句,你为什么要用简单工厂模式,我突然就愣住了,代码很简单,一看就懂了.重要的还是思想.专门定义

设计模式-创建型模式-工厂模式

创建型模式是为了隔离客户程序与具体类型实例化的依赖关系,通过将实例化职责委托他方法对象的方法,保证客户程序(或外部系统)获得期望具体类型实例的同时不必发生直接的引用. 概念: 工厂方法是整个创建型模式中最为典型的.也是最具启发效果的,它告诉我们使用一个变化频率比较高的类不比忙着new(),而是要依赖一个抽象的类型(抽象类或者接口).Delegate也是一个抽象,与抽象类型不同,它是对一类方法的抽象,而不像前两者是对一组方法的抽象.哪一种更好呢. 尺有所长,寸有所短. 如果需要的仅仅是某个特定的操

&lt;C/C++ 版&gt; 设计模式 学习之 策略模式+工厂模式

策略模式是一种定义一系列算法的方法,从概念上来讲,所有这些算法完成的都是相同的工作,只是实现不同,它可以以相同的方法调用所有的算法,减少各种算法类与使用算法类之间的耦合. 策略模式的 strategy (COperate)类层为 context 定义了一些了可供重用的算法或者行为,继承有助于析取这些算法中的公公功能. 策略模式简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试. 每个算法可以保证自身没有错误 ,修改其中的一个不会影响到其他算法. 测试代码如下: //Stra_F

创建型模式--工厂模式

 概述 定义一个用于创建对象的接口,让子类决定实例化哪一个类.FactoryMethod使一个类的实例化延迟到其子类.  适用性 1.当一个类不知道它所必须创建的对象的类的时候. 2.当一个类希望由它的子类来指定它所创建的对象的时候. 3.当类将创建对象的职责委托给多个帮助子类中的某一个,并且你希望将哪一个帮助子类是代理者这一信息局部化的时候.  参与者 1.Product 定义工厂方法所创建的对象的接口. 2.ConcreteProduct 实现Product接口. 3.Creator 声明工

设计模式-创建型模式-工厂模式-批量工厂

开发场景 实际项目中经常需要加工一批对象,这时候如果按部就班的一个一个来生成,效率相对上比较低,最好专门设计独立的批量工厂.很难想象调用"啤酒Factory"的Create()方法的时候,要经过工厂的一些列处理,最后才产生一瓶啤酒,如果有人要搞一件啤酒的时候,就要等24次处理,这就不行了.所以有了批量工厂. 实际项目中的开发过程也与此类似,但需要新增两个步骤. 1.准备生产:之前的实现中,实际加工对象的步骤其实就一个new(),但之前必须编写很多访问配置文件,寻找抽象产品类型需要实例化

python-单例模式&amp;工厂模式

1.单例模式 类外装饰器实现单例模式,是拦截整个实例化过程.(__new__;__init__) def singleton(cls): _instance = {} def func(*args,**kwargs): if cls not in _instance: _instance[cls] = cls(*args,**kwargs) return _instance[cls] return func @singleton class Test(object): def __init__(