简单工厂模式
依赖倒置原则(DIP)扶弱抑强 们应该优先依赖于抽象类,而避免依赖于具体类。当这些具体类不稳定时,更应该如此,因此下面的范例
它违反了DIP,SomeApp依赖于接口Shape,而且完全通过Shape接口来使用Shape的实例。它没有使用Square类或者Circle类的任何特定方法。糟糕的是,SomeApp也创建了Square和Circle的实例,因此就不得不依赖于这些具体类。
所以要用Factory模式来修正。
public interface ShapeFactory {
public Shape makeCircle();
public Shape makeSquare();
}
public class ShapeFactoryImplementation implements ShapeFactory{
@Override
public Shape makeCircle() {
return new Circle();
}
@Override
public Shape makeSquare() {
return new Square();
}
}
虽然还是要在其它某个地方创建ShapeFactoryImlementation,但是在所有其他的地方却根本不需要创建Square和Circle。而且,当使用一些反射等方法,例如Spring的依赖注入,就可以完全由Spring窗口来创建该实例。
不过还有个问题,针对每个Shape的派生类,ShapeFactory都要有一个对应的方法。这就产生了一个依赖关系环,使得每当Shape要添加一个派生类,就要改变ShapeFactory,为它增加一个方法,比如Shape有一个新派生类Rectangle,那么 ShapeFactory要加一个方法makeRectangle()。
可以牺牲一点类型安全性,来解决这个全副关系环。
public interface ShapeFactory {
public Shape make(String shapeName) throws Exception;
}
public class ShapeFactoryImplementation implements ShapeFactory{
@Override
public Shape make(String shapeName) throws Exception {
if(shapeName.equals("Circle"))
return new Circle();
else if(shapeName.equals("Square"))
return new Square();
else
throw new Exception("Create Shape Fail;");
}
}
测试类
public void testCreateCircle() throws Exception
{
Shape s = factory.make("Circle");
assert(s instanceof Circle);
}
虽然把Shape的名字拼错的调用者会得到一个运行期错误而不是一个编译错误但如果编写了适当数据的单元测试并且应用测试驱动的开发方法,那么远在这些运行期错误成为问题之前就可以捕获到它们。
在上面的简单工厂模式中,如果使用第一种模式,则需要在客户类中决定是调用makeCircle()还是makeSquare(),这就违背了工厂模式的初衷(即解开客户类和对象创建的耦合,客户类还是需要知道要创建的是circle还是square,这和new对象没什么区别)但如果使用第二种传参数的方法,则完全解开了这种耦合。
这样的话,甚至接口ShapeFactory都不要使用,直接客户类创建工厂对象,再给它传指定参数,它就可以创建所有的对象!!!但是,如果要创建的对象过多,或者创建对象要花费很多代码的话,那么这个工厂将会非常庞大,所以ShapeFactory接口还是必要的,这样就可以创建几个子类还把所有要创建的对象分开,你建这几个对象,我建这几个对象,这样可以使一个大类分割成几个小类,也能使结构更清晰。
工厂方法模式
工厂方法模式和工厂模式结构类似,但它的一个工厂实例只创建一个对象
代码就省略了,大家都懂得,但这里要吐槽一句,其实我一直没觉得工厂方法比简单工厂好在哪里,工厂方法要为了创建不同的对象要创建不同的方法实例,而简单工厂只要创建不同的String对象即可,
//简单工厂模式 只有一个工厂实例对象
public void SimpleFactory(){
Factory f = new FactoryImpl();
f.create("productA");
f.create("productB");
}
//下面是工厂方法模式 需要多个工厂实例对象
public void FactoryMethod(){
Factory fa = new FactoryImplA();
fa.create();
Factory fb = new FactoryImplB();
fb.create();
}
哪个看起来更好,不言而喻!如果说工厂方法模式相比简单工厂仅有的好处,那就是简单工厂需要传入的名字和对象的名字不断的比较,不仅浪费效率(真的会比创建多个工厂实例对象浪费的多吗?),而且还更丑陋(这才是主要的!)。
抽象工厂
说完工厂,再说说抽象工厂。抽象工厂和工厂完全是两码事。以前我一直以为它是工厂模式的升级版呢。
下面只写SimpleHome和AdvancesHome建造对象方面的代码。
//SimpleHome
public Products[] showMyHouse(){
Products bed = new ProductBed();
Products door = new ProductDoor();
return {bed,door};
}
//AdvancedHome
public Products[] showMyHouse(){
Products bed = new ProductBed();
Products door = new ProductDoor();
Products desk= new ProductDesk();
Products sofa= new ProductSofa();
return {bed,door,desk,sofa};
}
这个抽象工厂是用工厂方法模式写的,当然也可以把它改造成简单工厂模式,只要传入个参数"SimpleHome"或者"AdvancedHome"来让工厂实例决定创建哪种对象。
所以我们可以看出,抽象工厂模式和工厂模式虽然都名“工厂”,但它们却关注了不同的两个方面。模式的创建,无非就是低耦合,高聚合。模块与模块之间低耦合,模块内部高聚合。而这两个工厂模式,完全诠释了这一点。
工厂是解决了客户类和对象创建模块之间的耦合,只需要传一个参数,模块就可以创建不同的对象,而客户类对于对象的创建一无所知。而抽象工厂就是种高聚合。它聚合了simlehome和advancedhome对象的创建工程,使得在客户来看创建这两个对象非常简单,如果要simplehome,只需要创建一个SimpleHome工厂,并调用一下方法showMyHouse即可,而如果不用抽象工厂模式,就需要一个床工厂,一个门工厂,来分别创建bed和door对象。而如果Productes的子类更多,那么客户可以需要一堆的工厂。。。。。。。
但抽象工厂也有其自身的缺点,它提高了模块内的聚合性,那么它也降低了灵活性。如上图,你的家可以有一个bed一个door,也可以bed、door、desk、sofa都有,但如果我想要其中的三个,那就得再创建一个工厂实例,需要创建的对象任意组合,都需要相对应的工厂实例,即使是使用简单工厂的传参数方法,也需要一堆的代码加判断。所以抽象工厂更适合使用对象之间关系比较紧密的系统。就象上面所示,你的房子只有两个选择,要么简单的,要么高级的。
但如果我们能使用反射方法,那么就可以用简单工厂模式来传参数,然后再根据参数来创建不同的对象。(所以说简单工厂比工厂方面好太多了啊!)
- 大小: 41.3 KB
- 大小: 57.6 KB
- 大小: 42.9 KB
- 大小: 57.9 KB
分享到:
相关推荐
3. Qt工厂模式工程 4. Qt工厂模式例程 5. Qt工厂模式例子 6. 简单工厂模式 部分源码实例: // 奔驰工厂 class BenzFactory : public AFactory { public: ICar* CreateCar() { return new BenzCar(); } }; // ...
工厂模式,也称为工程模式或调试模式,是制造商为了测试和调整设备功能而设置的一种特殊模式。在这个模式下,用户可以访问和修改通常隐藏的高级设置,包括地图数据、系统参数以及硬件诊断。下面我们将详细介绍如何...
工厂模式是一种常用的软件设计模式,它是创建型设计模式的一种,主要解决对象的创建问题,将对象的创建过程封装起来,使得创建过程独立于使用过程。这样可以提高代码的可复用性和灵活性,同时降低了系统的耦合度。...
**简单工厂模式**是软件设计模式中的一种,属于创建型模式。在Java编程中,它是一种用于创建对象的简便方法,将对象的实例化过程封装到一个单独的工厂类中,使得客户端代码无需直接调用具体类的构造函数,而是通过...
- 关机状态下,同时按住“音量-”和“电源”键,屏幕亮起后松开,一般会进入工程模式,从中可以选择工厂模式。 4. MediaTek(联发科)机芯: - 长按遥控器的“设置”和“返回”键,开机后会进入工程模式,选择相应...
其中,"工程模式"是一个特殊的功能,通常隐藏在系统深处,主要用于制造商进行硬件测试和调试。对于用户而言,进入工程模式可以获取更多关于手机硬件的信息,进行高级设置,甚至解决一些特定问题。本篇文章将详细介绍...
在软件设计模式中,工厂模式是一组非常基础且实用的设计模式,主要分为简单工厂模式、工厂方法模式和抽象工厂模式。这些模式都是为了解决对象创建的问题,通过封装对象的创建过程,使得代码更加灵活,易于扩展和维护...
测试机型:32m3095(其它机型未试,大同小异,自行测试) 测试时间:2022.06.15 进入酒店模式好处:可以设置...进入工厂模式好处:可以设置不正常的颜色,声音。恢复系统默认设置。好多功能,是英文的,我看不懂。
根据提供的文档内容,本文将详细解释乐华板卡如何进入工程模式的方法,主要涉及Novatek和Realtek两种方案下的具体操作步骤。 ### 一、Novatek方案进特殊模式方法 #### 1. 板卡型号:PT系列 **1.1 工厂菜单** - *...
进入凯立德 工程模式 的方法 在“查找”菜单中切换到“123”输入法,输入*147#即可进入工程模式
"设计模式单例模式和工厂模式综合应用"的主题聚焦于两种常用的设计模式:单例模式和工厂模式,并探讨它们如何协同工作来实现高效、灵活的代码结构。这个主题尤其适用于Java编程语言,因为Java的面向对象特性使得设计...
在软件工程中,设计模式是解决常见问题的模板或最佳实践。工厂模式是其中最常用的一种,它提供了创建对象的最佳方式。在这个压缩包中,包含了三种工厂模式的C++实现:简单工厂模式、工厂方法模式以及抽象工厂模式。...
以下是关于JAVA设计模式中提及的四种模式——工厂模式、代理模式、迭代器模式以及责任链模式的详细说明。 1. **工厂模式**:工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。在工厂模式中,当创建...
"C++设计模式-工程模式"这个标题暗示我们将深入探讨C++中的一种核心设计模式——工厂模式。工厂模式是创建型设计模式,它提供了一种创建对象的最佳方式,允许我们在不指定具体类的情况下创建对象。在描述中提到的...
本文将探讨三个重要的设计模式:抽象工厂模式、工厂方法模式以及策略模式,并结合一个实际的场景——手机加工厂,来具体阐述它们的应用。 首先,我们来看**抽象工厂模式**。这个模式主要用于创建相关或依赖对象的...
《工厂模式源代码》 工厂模式是软件设计模式中的一种,属于创建型模式,它提供了一种创建对象的最佳方式。在工厂模式中,当我们创建对象时,不会直接实例化具体的产品类,而是通过一个共同的接口或者抽象类,即工厂...
工厂方法模式和抽象工厂模式是两种常见的设计模式,它们都属于创建型模式,用于解决对象的创建问题。在软件设计中,这两种模式都是用来隔离对象的创建和使用,以提高系统的灵活性和可扩展性。 首先,工厂方法模式的...
在软件设计模式中,工厂模式是一种非常常用的行为型模式,它的主要目的是为了隔离对象的创建过程,使得客户端代码不直接创建对象,而是通过一个工厂类来负责对象的创建。这样可以使得系统更具可扩展性和可维护性。...
工厂模式是一种设计模式,它是创建型模式的一种,主要用于在代码中抽象出对象的创建过程,使得创建对象的过程与具体的实现分离,从而提高了代码的可扩展性和可维护性。在这个"工厂模式(2016手机案例)"中,我们将...