3 回答
TA贡献1780条经验 获得超1个赞
所有三种工厂类型都做同样的事情:它们是“智能构造函数”。
假设您希望能够创建两种水果:Apple和Orange。
厂
工厂是“固定的”,因为你只有一个没有子类化的实现。在这种情况下,您将拥有这样的类:
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(); }}
TA贡献1856条经验 获得超11个赞
这三种模式如何相互不同?
Factory:创建对象而不将实例化逻辑暴露给客户端。
工厂方法:定义用于创建对象的接口,但让子类决定实例化哪个类。Factory方法允许类将实例化延迟到子类
抽象工厂:提供用于创建相关或从属对象族的接口,而无需指定其具体类。
AbstractFactory模式使用组合将创建对象的责任委托给另一个类,而Factory方法设计模式使用继承并依赖派生类或子类来创建对象
什么时候用哪个?
工厂:客户只需要一个类,而不关心它正在实现哪个具体实现。
工厂方法:客户端不知道在运行时需要创建哪些具体类,但只想获得一个可以完成工作的类。
AbstactFactory: 当您的系统必须创建多个系列的产品或您想要提供产品库而不暴露实现细节时。
抽象工厂类通常使用Factory Method实现。工厂方法通常在模板方法中调用。
如果可能的话,任何与这些模式相关的java示例?
工厂和工厂方法
意图:
定义用于创建对象的接口,但让子类决定实例化哪个类。Factory Method允许类将实例化延迟到子类。
UML图:
Product:它定义Factory方法创建的对象的接口。
ConcreteProduct:实现产品界面
创建者:声明工厂方法
ConcreateCreator: 实现Factory方法以返回ConcreteProduct的实例
问题陈述:使用工厂方法创建游戏工厂,工厂方法定义游戏界面。
代码段:
工厂模式。何时使用工厂方法?
与其他创作模式比较:
设计从使用工厂方法(不太复杂,可定制,子类增加)开始,并逐渐向Abstract Factory,Prototype或Builder发展(更灵活,更复杂),因为设计师发现需要更多灵活性的地方
抽象工厂类通常使用工厂方法实现,但也可以使用Prototype实现
添加回答
举报