コンテンツにスキップ

オブジェクト指向設計@アーキテクチャ

はじめに

本サイトにつきまして、以下をご認識のほど宜しくお願いいたします。


01. オブジェクト指向設計

構造の視点

クラス図、ER図などがある。


振舞の視点

シーケンス図などがある。


構造とビジネスルール/制約の視点

ドメインモデル図がある。


02. クラス図

クラス図とは

クラス間の関係性を基に、ソフトウェアの『静的構造』を表す。

オブジェクト図のインスタンス間の関係性を参考にして、クラス間の関係性の種類を判断する。


記法の種類

▼ has-one、has-many (データとして保持する関係性)

データとして保持する関係性

『has-one』『has-many』な関係と表現され、より具体的に説明すると、とデータとして保持する関係性である。

Association (関連) 、Aggregation (集約) 、Composition (合成) が使用される。

『Association > Aggregation > Composition』の順で、依存性が低くなる。実装例は以下のリンクを参考にせよ。

▼ is-a-kind-of (グループとメンバーの関係性)

グループとメンバーの関係性

『is-a-kind-of』な関係と表現され、より具体的に説明すると、とグループとメンバーの関係性である。

Generalization (汎化) 、Realization (実現) が使用される。実装例は以下のリンクを参考にせよ。

▼ use (引数型/返却値型として使用する関係性)

引数型または返却値型として使用する関係性

『use』な関係と表現され、より具体的に説明すると、と引数型/返却値型として使用する関係性である。

Dependency (依存) が使用される。

実装例は以下のリンクを参考にせよ。


データとして保持する関係性の多重度

▼ multiplicity (多重度) とは

クラス間がデータとして保持する関係性にある時に、保持される側クラスが何個のクラスに保持されるか、また反対に保持する側クラスが保持される側クラスを何個保持するかを表す。

このように2個の見方があることが混乱するので注意する。

オブジェクト図のインスタンス間のリンク記号数を参考にして定義する。

▼ 記法

保持する/保持されるクラスの個数 記法
1 1
0以上1以下 (つまり、0または1) 0..1
0以上n以下 0..n
m以上n以下 m..n
0以上無限大以下 (つまり、0以上) *
0以上無限大以下 (つまり、0以上) 0..*

*例*

社員は1個の会社にしか所属できないとする。

『社員クラス』から見た時に、1個の『会社クラス』にしか保持されない。

よって、会社クラスに『1』を付記する。

一方で『会社クラス』から見た時に、0以上の『社員クラス』を保持する。

よって、会社クラスに『0..*』を付記する。

多重度


03. ER図:Entity Relation Diagram

ER図とは

DBテーブルのカラム間の関係性を基に、DBの構造を表す。

『IE記法』と『IDEF1X記法』が一般的に使用される。


IE記法

▼ IE記法とは

er-diagram_ie

▼ エンティティ、属性

テーブルに相当するエンティティと、カラムに相当する属性がある。

エンティティとアトリビュート

▼ リレーション、カーディナリティ

リレーションとカーディナリティを組み合わせて、エンティティ間の関係性の強さを表す。

(カラム数/レコード数)で導かれ、カーディナリティが高いほど、より効率的なDBインデックスを作成できる。

リレーションとカーディナリティ


関係性の種類

▼ 1:1

1対1

▼ 1:多 (リレーションが曖昧な状態)

オブジェクト指向分析が進むにつれ、『1:0 以上の関係』『1:1 以上の関係』のように具体化しく。

1対1以上

▼ 1:1 以上

1対1以上


04. シーケンス図

シーケンス図とは

オブジェクト間の時系列的な関係性を基に、ソフトウェアの『動的な振舞』を表すダイアグラムのこと。

記号名 説明 補足
ライフライン オブジェクト (クラス、インスタンス) を表す。 粒度を大きくして、システムのコンポーネントをライフラインとすることもある。
実行仕様 ライフライン上で実行されている処理を表す。
停止 ライフラインが削除されることを表す。
同期メッセージ 既存のライフラインを同期的にコールすることを表す。
非同期メッセージ 既存のライフラインを非同期的にコールすることを表す。
生成メッセージ ライフラインを新しく作成することを表す。
自己メッセージ ライフラインが、自分自身の内部処理をコールして処理を繰り返すことを表す。 https://www.lesswrong.com/posts/gQ5eQjRTY87LpjhQv/when-to-use-meta-vs-self-reference-recursive-etc>
再帰的メッセージ ライフラインが、自分自身全体をコールして処理を繰り返すことを表す。 https://www.lesswrong.com/posts/gQ5eQjRTY87LpjhQv/when-to-use-meta-vs-self-reference-recursive-etc>
入れ子実行仕様 再帰的メッセージによってコールされた別の実行仕様を表す。
返却メッセージ コールの結果を他のライフラインに返却することを表す。
複合フラグメント (結合フラグメント) 条件分岐、繰り返しなどによって実行されたコールであること表す。実行仕様とメッセージを四角で囲い、左上隅にオペレーター名を記載する。 条件分岐の場合はオペレーター名をalt (alternative) 、繰り返しの場合はloopとする。
https://qiita.com/devopsCoordinator/items/4535c3cce207b114ad6c#%E8%A4%87%E5%90%88%E3%83%95%E3%83%A9%E3%82%B0%E3%83%A1%E3%83%B3%E3%83%88>

*例*

(1)

5つのライフライン (店員オブジェクト、管理画面オブジェクト、検索画面オブジェクト、商品DBオブジェクト、商品詳細画面オブジェクト) を設定する。

(2)

各ライフラインで実行される実行仕様間の命令内容を、メッセージや複合フラグメントで示す。

シーケンス図

*例*

(1)

3個のライフラインを設定する。

(2)

各ライフラインで実行される実行仕様間の命令内容を、メッセージや複合フラグメントで示す。

シーケンス図_2


05. コンポーネント図

複数のクラスから構成される処理を1個の図で表現した図のこと。

記号名 説明
コンポーネント名 処理コンポーネントを表す。
提供側インターフェース
要求側インターフェース