ファクトリパターンを完全に理解するかどうかはよくわかりません。
Customer
基本的に次のメソッドを持つクラスがあるとしましょう。
CreateCustomer
-静的、顧客を最初から作成してデータベースに追加し、LoadCustomer
Customer
-静的、データベースからのインスタンスをロードし、KillCustomer
-静的ではなく、データベースから顧客を削除します。
よく理解できれば
LoadCustomer
ファクトリクラスに入れるのに適した候補です。- どう
CreateCustomer
ですか?ファクトリクラスに入れることができると思います。そうですか?そうでない場合、静的CreateCustomer
メソッドはデータベースの状態を変更してから、を呼び出しますCustomerFactory.LoadCustomer
。私見、これは悪い設計です。特定のオブジェクトは、自分のファクトリについて何も知る必要はありません。 KillCustomer
ファクトリの非常に悪い候補のように思えます。ファクトリは、オブジェクトを作成するのではなく、すでに作成されたオブジェクトに作用します。一方で:- 非静的メソッドが顧客をデータベースから削除した場合でも、(
KillCustomer
呼び出された)オブジェクトは引き続き存在します。これは、オブジェクトがデータベースレベルで自殺し、ビジネスレベルで残っているのを見るのは非常に奇妙です。このレベルでは、工場からの電話KillCustomer
の方が合理的です。たとえば、オブジェクトがアプリケーションにキャッシュされている場合、ファクトリはデータベースとキャッシュの両方からオブジェクトを削除する場合があります。 - オブジェクトを作成するメソッドとオブジェクトを削除するメソッドを異なるクラスに入れるのも奇妙に思えます。なぜファクトリーは何かを構築するだけで、構築されたものを決して破壊できないのですか?
- 非静的メソッドが顧客をデータベースから削除した場合でも、(
最後になりましたが、顧客がアプリケーションにキャッシュされているとしましょう。キャッシュの管理は誰が担当しますか?IMO、ファクトリはそれを実行する必要があります。オブジェクトを作成するため、データベースからプロパティが入力された新しいオブジェクトをロードする必要があるか、オブジェクトがすでにキャッシュに存在するかを選択することをお勧めします。
では、ファクトリパターンについて考えていることの何が正しく、何が間違っているのでしょうか。