Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
オブジェクト指向設計はどうして必要とされたか
Search
まりも
September 24, 2024
0
67
オブジェクト指向設計はどうして必要とされたか
オブジェクト指向の説明を、なぜオブジェクト指向が必要とされ現れたかの観点からまとめてみました。
まりも
September 24, 2024
Tweet
Share
More Decks by まりも
See All by まりも
メンタルモデルから見るオブジェクト設計
hrmstrsmgs
0
14
技術的負債
hrmstrsmgs
0
15
よい設計のプログラムを作るには
hrmstrsmgs
0
28
歴史から理解するJavaScript
hrmstrsmgs
0
14
論理的な考え方
hrmstrsmgs
0
15
論理的な話し合いはなぜ必要か
hrmstrsmgs
0
5
腕のある技術者はなぜ
hrmstrsmgs
0
13
疑似乱数の生成
hrmstrsmgs
0
7
構造化プログラミング
hrmstrsmgs
0
13
Featured
See All Featured
ReactJS: Keep Simple. Everything can be a component!
pedronauck
663
120k
The Cost Of JavaScript in 2023
addyosmani
43
5.8k
Side Projects
sachag
452
42k
5 minutes of I Can Smell Your CMS
philhawksworth
202
19k
Done Done
chrislema
181
16k
StorybookのUI Testing Handbookを読んだ
zakiyama
26
5.1k
Rebuilding a faster, lazier Slack
samanthasiow
79
8.6k
The Brand Is Dead. Long Live the Brand.
mthomps
53
38k
Faster Mobile Websites
deanohume
304
30k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
43
6.5k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
28
7.5k
Principles of Awesome APIs and How to Build Them.
keavy
126
17k
Transcript
オブジェクト指向設計 とか抽象データ型とかドメイン駆動設計とか
よい設計 今日の資料は作ってい て気合が入りました 私はこのために生きているのかもしれない
よい設計はなぜ大切か
目的 目的 まず目的を明確にします
よい設計はなぜ大切か プログラムはどんどん 複雑になっています よほど整理し ないとわけが 分からない 最近のOSで1億行くらい?
よい設計はなぜ大切か うまい 整理 よい 設計
動くプログラム 動くかどうかはどうでもいい
動くプログラム この仕様なら要件を満た せるとかどうでもいい
動くプログラム この仕様なら要件を満た せるとかどうでもいい
動くプログラム 完成したプログラムは最低でも動いてはいる 動いてからが勝負 そもそも動くだけなら1950年代の技術で十分
動作 この仕様なら要件を満たせるとかどうでもいい そこから先が勝負 そうしないと、仕様を追加していくうちにどうせ動か くなりますからね
よい設計 よい設計 保守 拡張性
どれだけ整理すればよいのか?
どれだけ整理すればよいのか? 方向はわかった 距離は?
どれだけ整理すればよいのか? 文章や図を 使って最もわ かりやすく
シンプル ものごとはできるかぎりシンプルに すべきだ。しかし、シンプルすぎて もいけない。 • アルバート・アインシュタイン
プログラム分野では • 必要な要件を正しく表現し、できる限り少 ない要素の組み合わせて説明する • できるだけ少ない実装ではないことに注意 できるかぎり シンプルに • 要件の説明を省略するために正しさを端
折ってはいけない • 実装できてもだめ シンプルすぎ てもいけない。
実装 表現はなるべく自然言語に近いレベルでわかりやすく この技術は日進月歩なので、最新のライブラリを参考に シンプルな説明に出てきた図、単語をそのままプログラムにする オブジェクト指向
整理のための方法
構造化 ツリーにしてわかりやすく
結合度・凝集度 • よそのモジュールのことを知らない といけない度合い • 小さいほうが良い 結合度 • 同じモジュールでは統一された内容 を各度合
• 大きい方がよい 凝集度
オブジェクト指向 すべてはオブジェクト 構造化を簡単に実装 データと処理を関連付ける カプセル化 継承
ドメイン駆動設計 • 単にオブジェクト指向 じゃないですかね? • ビジネスロジックのため のデザインパターンが必 要 ドメイン駆動設計(英: domain-
driven design, DDD)とはソフト ウェアの設計手法であり、「複雑 なドメインの設計は、モデルベー スで行うべき」であり、また「大 半のソフトウェアプロジェクトで は、システムを実装するための特 定の技術ではなく、ドメインその ものとドメインのロジックに焦点 を置くべき」であるとする。 (Wikipedia)
DSL 複雑なライブラリは内部DSLとして実装すべき。 特定タスク向けの簡易言語 外部DSL 内部DSL