デザインパターン (ソフトウェア)

デザインパターン (ソフトウェア)の最新ニュースをまとめて検索!

ソフトウェア開発におけるデザインパターン(型紙(かたがみ)または設計パターン: design pattern)とは、過去のソフトウェア設計者が発見し編み出した設計ノウハウを蓄積し、名前をつけ、再利用しやすいように特定の規約に従ってカタログ化したものである。

目次

[編集] 概要

書籍『オブジェクト指向における再利用のためのデザインパターン』において、GoF (Gang of Four; 四人組) と呼ばれる4人の共著者は、デザインパターンという用語を初めてソフトウェア開発に導入した。GoFは、エーリヒ・ガンマリチャード・ヘルムラルフ・ジョンソンジョン・ブリシディースの4人である。

彼らはこう述べている。

[Design patterns] solve specific design problems and make object-oriented designs more flexible, elegant, and ultimately reusable. They help designers reuse successful designs by basing new designs on prior experience. A designer who is familiar with such patterns can apply them immediately to design problems without having to rediscover them.

コンピュータプログラミングで、素人達人の間ではびっくりするほどの生産性の差があるが、その差はかなりの部分が経験の違いからきている。達人は、さまざまな難局を、何度も何度も耐え忍んで乗り切ってきている。そのような達人たちが同じ問題に取り組んだ場合、典型的にはみな同じパターンの解決策にたどり着くのだが、これがデザインパターンである (GoF)。

それぞれのパターンは、プログラマの間で何度も繰り返し考え出されてきた。したがって、それは最善の解決策ではないかもしれないが、その種の問題に対するトレードオフも考慮した、典型的な解決策ではある。更に、コストがかかるかもしれない問題解決を実際に行う前の先行調査として大変役に立つ。パターンには名前がついていることが重要である。なぜなら、名前がついていることで問題や解決策を記述したり、会話の中で取り上げたりすることができるようになるからである。

[編集] GoFによる23のパターン

GoFは彼らの著作『オブジェクト指向における再利用のためのデザインパターン』の中で23種のパターンを取り上げた。

[編集] 生成に関するパターン

Abstract Factory パターン
関連する一連のインスタンスを状況に応じて適切に生成する方法を提供する。
Builder パターン
複合化されたインスタンスの生成過程を隠蔽する。
Factory Method パターン
実際に生成されるインスタンスに依存しない、インスタンスの生成方法を提供する。
Prototype パターン
同様のインスタンスを生成するために、原型のインスタンスを複製する。
Singleton パターン
あるクラスについて、インスタンスが単一であることを保証する。

[編集] 構造に関するパターン

Adapter パターン
元々関連性のない2つのクラスを接続するクラスを作る。
Bridge パターン
クラスなどの実装と、呼出し側の間の橋渡しをするクラスを用意し、実装を隠蔽する。
Composite パターン
再帰的な構造を表現する。
Decorator パターン
あるインスタンスに対し、動的に付加機能を追加する。Filterとも呼ばれる。
Facade パターン
複数のサブシステムの窓口となる共通のインタフェースを提供する。
Flyweight パターン
多数のインスタンスを共有し、インスタンスの構築のための負荷を減らす。
Proxy パターン
共通のインタフェースをもつインスタンスを内包し、利用者からのアクセスを代理する。Wrapperとも呼ばれる。

[編集] 振る舞いに関するパターン

Chain of Responsibility パターン
イベントの送受信を行う複数のオブジェクトを鎖状につなぎ、それらの間をイベントが渡されてゆくようにする。
Command パターン
複数の異なる操作について、それぞれに対応するオブジェクトを用意し、オブジェクトを切り替えることで操作の切替えを実現する。
Interpreter パターン
構文解析のために、文法規則を反映するクラス構造を作る。
Iterator パターン
複数の要素を内包するオブジェクトのすべての要素に順にアクセスする方法を提供する。反復子
Mediator パターン
オブジェクト間の相互作用を仲介するオブジェクトを定義し、オブジェクト間の結合度を低くする。
Memento パターン
データ構造に対する一連の操作のそれぞれを記録しておき、以前の状態の復帰または操作の再現が行えるようにする。
Observer パターン
インスタンスの変化を他のインスタンスから監視できるようにする。Listenerとも呼ばれる。
State パターン
オブジェクトの状態を変化させることで、処理内容を変えられるようにする。
Strategy パターン
データ構造に対して適用する一連のアルゴリズムカプセル化し、アルゴリズムの切替えを容易にする。
Template Method パターン
あるアルゴリズムの途中経過で必要な処理を抽象メソッドに委ね、その実装を変えることで処理が変えられるようにする。
Visitor パターン
データ構造を保持するクラスと、それに対して処理を行うクラスを分離する。

[編集] 参考文献

[編集] 関連項目

ウィキメディア・コモンズ

最終更新 2009年11月19日 (木) 09:46 (日時は個人設定で未設定ならばUTC)。
【デザインパターン (ソフトウェア)】変更履歴

ご利用上の注意