リファクタリング

Factoryによるクラス群の隠蔽

兆候

1つのパッケージ内にある共通のインタフェースを実装しているクラス群を、クライアントが直接インスタンス化 している。

before.jpg

処置

クラスのコンストラクタをパブリックでなくし、クライアントにはFactory経由でインスタンスを生成させる。

after.jpg

動機

クライアントが直接クラスをインスタンス化できて役立つのは、それらのクラスの存在そのものを知る必要が ある場合だけである。

「共通インタフェースを実装したインスタンスを生成して返す」という責務をFactoryに持たせることで、クライアントからパッケージ内のクラスを隠蔽することができる。 これによって、

手順

  1. ある種類のインスタンスを生成するために、クラスのコンストラクタを呼び出している箇所を探す。
    • メソッドの抽出をコンストラクタの呼び出し部分に適応し、パブリックなstaticメソッドを作成する。
    • メソッドの移動 を適用して、選択したコンストラクタを持つスーパークラスに生成メソッドを移動する。
  2. 生成メソッドと同じ種類のインスタンスを生成するために、先に選択したコンストラクタを呼び出している部分をすべて洗い出し、生成メソッドを呼び出すように変更する。
  3. クラスのコンストラクタが生成するインスタンスの種類毎に、ステップ1,2を繰り返す
  4. クラスのコンストラクタをパブリック以外に変更する。
  5. カプセル化したいすべてのクラスについて、ステップ1〜4を繰り返す。

コメント


(Input image string)

トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS
SmartDoc