当前位置: 首页 > 面试题库 >

Java设计模式:Factory vs Factory method vs Abstract Factory

申屠洛华
2023-03-14
问题内容

我正在从网站上阅读设计模式

在那里我读到了有关Factory,Factory方法和Abstract工厂的信息,但是它们是如此混乱,在定义上还不清楚。根据定义

工厂-在不将实例化逻辑暴露给客户端的情况下创建对象,并通过公共接口引用新创建的对象。是Factory Method的简化版本

工厂方法-定义用于创建对象的接口,但让子类决定要实例化的类,并通过通用接口引用新创建的对象。

抽象工厂-提供用于创建相关对象族的接口,而无需显式指定其类。

我还查看了有关抽象工厂与工厂方法的其他stackoverflow线程,但是在那里绘制的UML图使我的理解更糟。

谁能告诉我

  • 这三种模式有何不同?
  • 什么时候使用?
  • 还有可能的话,是否有任何与这些模式相关的Java示例?

问题答案:

所有这三种Factory类型都执行相同的操作:它们是“智能构造函数”。

假设你希望能够创建两种水果:Apple和Orange。


Factory是“固定的”,因为你只有一个实现,没有子类。在这种情况下,你将拥有一个像这样的类:

class FruitFactory {

  public Apple makeApple() {
    // Code for creating an Apple here.
  }

  public Orange makeOrange() {
    // Code for creating an orange here.
  }

}

用例:构造Apple或Orange太复杂,以至于无法在构造器中进行处理。

工厂方法

当你在类中进行了一些通用处理,但又想改变你实际使用哪种水果时,通常使用工厂方法。所以:

abstract class FruitPicker {

  protected abstract Fruit makeFruit();

  public void pickFruit() {
    private final Fruit f = makeFruit(); // The fruit we will work on..
    <bla bla bla>
  }
}
...然后你可以FruitPicker.pickFruit()通过在子类中实现工厂方法来重用常用功能:

class OrangePicker extends FruitPicker {

  @Override
  protected Fruit makeFruit() {
    return new Orange();
  }
}

抽象工厂
当你希望能够创建需要“相同种类”并具有一些通用基类的整个对象系列时,抽象工厂通常用于诸如依赖性注入/策略之类的事情。这是一个与水果相关的模糊示例。这里的用例是我们要确保我们不会意外地在Apple上使用OrangePicker。只要我们从同一家工厂获得水果和捡拾器,它们就会匹配。

interface PlantFactory {

  Plant makePlant();

  Picker makePicker(); 

}

public class AppleFactory implements PlantFactory {
  Plant makePlant() {
    return new Apple();
  }

  Picker makePicker() {
    return new ApplePicker();
  }
}

public class OrangeFactory implements PlantFactory {
  Plant makePlant() {
    return new Orange();
  }

  Picker makePicker() {
    return new OrangePicker();
  }
}


 类似资料:
  • 设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。

  • 设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。本教程将通过 Java 实例,一步一步向您讲解设计模式的概念。

  • Sunny在CSDN技术博客中陆续发表了100多篇与设计模式学习相关的文章,涵盖了七个面向对象设计原则和24个设计模式(23个GoF设计模式 + 简单工厂模式),为了方便大家学习,quanke 现将所有文章的进行了整理,方便大家下载阅读,希望能给各位带来帮助! 阅读地址:https://quanke.gitbooks.io/design-pattern-java/content/ 下载地址:htt

  • 本文向大家介绍java  设计模式之单例模式,包括了java  设计模式之单例模式的使用技巧和注意事项,需要的朋友参考一下 java  设计模式之单例模式 前言: 在软件开发过程中常会有一些对象我们只需要一个,如:线程池(threadpool)、缓存(cache)、对话框、偏好设置等。这些对象如果制造出多个实例的话可能会导致一些不必要的麻烦,如:程序行为异常、资源使用过量等。这时单例模式就可以确保

  • 本文向大家介绍java设计模式之单例模式,包括了java设计模式之单例模式的使用技巧和注意事项,需要的朋友参考一下 单例模式也叫做单肩模式,也是一种创建型模式,是我们日常开发中最常使用的一种设计模式,经常被用来封装一些工具类,例如数据库连接等。 单例模式的定义: 单例模式,是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中一个类只有一个实例。即一个类

  • 本文向大家介绍java设计模式之观察者模式,包括了java设计模式之观察者模式的使用技巧和注意事项,需要的朋友参考一下         观察者模式又称发布-订阅(Publish/Subscribe)模式,定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态发生变化时,会通知所有观察者对象,使他们能够自动更新自己。将一个系统分割成一系列相互协作的类有一个很不好的副作

  • 本文向大家介绍java设计模式之桥接模式(Bridge),包括了java设计模式之桥接模式(Bridge)的使用技巧和注意事项,需要的朋友参考一下 概述 桥接模式一种结构型模式,它主要应对的是:由于实际的需要,某个类具有两个或以上的维度变化,如果只是用继承将无法实现这种需要,或者使得设计变得相当臃肿。 桥接模式的做法是把变化的部分抽象出来,使变化部分与主类分离开来,从而将多个维度的变化彻底分离。最

  • 本文向大家介绍java设计模式之适配器模式,包括了java设计模式之适配器模式的使用技巧和注意事项,需要的朋友参考一下 感谢《Android源码设计模式解析与实战》 何红辉 关爱民 著  适配器模式在我们的开发中使用率极高,从代码中随处可见的Adapter就可以判断出来,从最早的ListView、GridView、到现在最新的RecyclerView都需要使用Adapter,并且在开发中我们遇到的