三個概念:
簡單工廠模式:就是一個簡單的工廠類,根據不同的入參類型,返回不同的父類引用的子類對象。
工廠方法模式:就是將生成哪個子類對象的過程,延遲到工廠子類實現,工廠父類只定義接口。
抽象工廠模式:就是在工廠方法模式的基礎上,將使用哪個工廠子類的邏輯,再使用簡單工廠的模式生成。
互相關係
工廠方法模式,就是對簡單工廠模式的改進。
抽象工廠模式,就是對工廠方法的改進。
優缺點
簡單工廠模式,就是簡單,但不符合開閉原則(新增類,需要修改工廠類)
爲了解決簡單工廠模式的開閉原則,出現了工廠方法模式。
工廠方法模式,新增類不需要修改工廠類,但可能需要新增對應的工廠類。而且多個工廠類之間,沒有太多聯繫,不好管理。
抽象工廠模式,用簡單工廠模式的套路管理了工廠方法模式的多個工廠類。但缺點就是不簡單了,想簡單點,就用簡單工廠模式吧。
可以看出,這三個工廠模式,按照順序,每個模式都是爲了解決上一個模式的問題,但同時又有了新的問題。
舉個不太恰當但很形象的例子:
背景是乙方向甲方提供一份項目的一個模塊的設計。
一開始,乙方說用簡單工廠模式,甲方說不好。
然後乙方改進後,說用工廠方法模式吧,甲方猶豫了一會說,覺得還能更好。
然後乙方又改進,說那就用抽象工廠模式吧,甲方看了半天,點點頭說,好是好,就是有點複雜,後期怕是不好維護。
最終,甲方使用了第一版的簡單工廠模式。