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
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.
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.