Why does Abstract Factory deal with families, and Factory Method with generating a single object?

前端 未结 2 1011
粉色の甜心
粉色の甜心 2020-12-21 12:14

From what I have read, the abstract factory pattern typically concerns itself with creating several objects which are all associated with the same family, and the factory me

相关标签:
2条回答
  • 2020-12-21 12:54

    In the given examples, BasePizzaCreator is an Abstract Factory, but IPizzaFactory is not any GoF design pattern (though it is sometimes referred to as a Simple Factory).

    As to why Abstract Factory deals with product families while Factory Method deals with a single product: that's simply how the GoF defined them. The GoF book mentions the most common way to implement an Abstract Factory is with multiple Factory Methods; but I've not seen that in practice. From a client's perspective, Abstract Factory may be preferable because clients invoke it through composition/delegation, as opposed to Factory Method which requires clients to inherit that method.

    Finally, note that "Abstract Factory vs. Factory Method" is the second-most popular design patterns topic on Stack Overflow. Unfortunately, there is a lot of (highly-upvoted) misinformation posted as well, so when in doubt, always refer back to the book.

    • Differences between Abstract Factory Pattern and Factory Method
    • Design Patterns: Abstract Factory vs Factory Method
    • Design Patterns: Factory vs Factory method vs Abstract Factory
    • Factory, Abstract Factory and Factory Method
    0 讨论(0)
  • 2020-12-21 13:02

    That's the difference in intent of these two patterns.

    FactoryMethod : Define an interface for creating an object, but let subclasses decide which class to instantiate. FactoryMethod lets a class defer instantiation to subclasses.

    AbstractFactory: Provide an interface for creating families of related or dependent objects without specifying their concrete classes.

    AbstractFactory classes are often implemented with FactoryMethods but they can be implemented even with Prototypes

    Generally design start with FactoryMethod and may evolve towards other creational patterns like AbstractFactory, Prototype or Builder

    I too agree with @jaco0646 answer regarding advantage of using AbstractFactory (uses delegation/composition) from client instead of using FactoryMethod (which based on inheritance)

    Regarding your last query:

    Why is Abstract Factory the better approach for creating families of related objects, and Factory method the better approach to creating a single object?

    Yes. Both have meant for different purpose as quoted in the intent.

    AbstractFactory has advantage of returning one of the products from a family.

    Advantage of FactoryMethod: It can return the same instance multiple times, or can return a subclass rather than an object of that exact type.

    Refer to this sourcemaking link for better understanding of these patterns.

    0 讨论(0)
提交回复
热议问题