skillup

技術ブログ

アーキテクト設計全般

オブジェクト指向 クラスの設計と業務ロジックの整理

投稿日:2017年7月21日 更新日:

本日も引き続き「現場で役立つシステム設計の原則」を読み進めてます。

本日は主にクラスの作り方について。

クラス設計と業務ロジック

要点

  • データを入れるだけのクラスを書かない
  • データとメソッドを一か所にまとめる
  • 関連するロジックを3層(アプリケーション層、データ層、プレゼンテーション層)で使うとそれぞれの構造に依存したメソッドができてしまう
  • 上記問題点を解決するため3層の関心ごとと業務ロジックを分離する
  • 下手に汎用ライブラリ(Util系)にメソッドを集めすぎない
  • コントローラー側は基本メソッドを呼び出すだけ、データは受け取るだけ
  • 必ずインスタンス変数を使って処理を行う(オブジェクト指向の原則はまとめる、隠す、たくさんつくる)
  • 関連するデータとメソッドを一か所に「閉じ込める」意識を持つ
  • クラスが肥大化したら分ける→ロジックとメソッドが完全に密接するようにする(凝縮度を高くする)
  • なるべく小さい単位に分ける注文クラスとかはだめドメイン単位で分ける
  • 大きいクラスのまとまりをパッケージとして管理する。例えば注文(Order)などとという業務単位は大きすぎるため、通常はパッケージとして管理し、関連する関心ごとをクラスとして設計する。
  • 3層アーキテクチヤでクラスの設計+業務の関心事(ドメインモデル)でクラスを設計する

感想

これまでの自分のやり方なんですが、MVCモデルによって作られたフレームワークで仕事を進めることが多かったのでこれを踏襲する形で仕事はしていました。

ただクラスという概念を有効活用できていませんでしたね・・本書ではただデータを入れるだけのクラスをデータクラスと呼びこの活用法を批判していますが、データだけを格納したクラスを使うとロジックがあちらこちらに分離して変更コストが馬鹿になりません。

私の場合、モデルにあたる部分の担当が多すぎて、基本DBからデータとってコントローラでひたすらハッシュでぐるぐる回して画面に吐くという処理を繰り返していました・・これだとテストもコントローラに依存するのでやりにくいですしね・・・

この本でいわれているように同じようなロジックがあちこちらに散在しているというような問題点が頻発していました。対応策としてはやはり業務ロジックをMVCに従ってかかないということですね。このために必要な考え方がドメイン駆動設計なのだと思います。

-アーキテクト設計全般
-

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

no image

スクラム開発をやってみて

アジャイルの定義に関してはエンジニアによって色々なものがあると思われますが、自分の場合一番綺麗に説明されているな・・・と感じたのは以下の記事でも紹介した書籍でした。 アジャイル開発について 現場ではた …

no image

アプリケーション間のデータの連携方法に関して

以前やった「現場で役立つシステム設計の原則」を再読してます。 今、読んでいるのはアプリ間のデータ連携に関して。 複数のアプリ間でデータをやり取りする場合、以下のような方法が考えられます。 ファイルを直 …

no image

エラーの告知や収集、通知などについて

障害対応時は基本的にエラーの情報を見て以下のようなことを考えることになりますが、 どういうエラーを出すのか どのようにエラーを拾うのか システム管理者にどのように告知するのか などはいろいろ議論の余地 …

no image

オブジェクト指向 プレゼンテーション層

本日も引き続き「現場で役立つシステム設計の原則」を読み進めてます。 本日はプレゼンテーション層、いわゆるMVCのViewにあたる部分。 Contents1 プレゼンテーション層の考え方1.1 要点1. …

no image

キャッシュの使い所とメリデメに関して(主に一覧系の処理に関して)

現在のプロジェクトがかなりの規模のECサイトになるため、正確性とパフォーマンスのトレードオフなどが先日議題にあがりました。 完全なトレードオフではないのかもしれませんが、比較的あちらをたてればこちらが …

アーカイブ