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
Application Design 勉強会 #2
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kazuki Chigita
June 26, 2019
Technology
340
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Application Design 勉強会 #2
Application Application Design 勉強会 #2
Kazuki Chigita
June 26, 2019
More Decks by Kazuki Chigita
See All by Kazuki Chigita
あの日のHotReloadはなぜ動かなかったのか? 〜OSセキュリティ(W^X)とJITコンパイラの攻防〜
chigichan24
3
1.2k
「 動く」サンプルでスムーズなコミュニケーションを
chigichan24
1
1.1k
Claude CodeでサクサクTestコードを移行しよう
chigichan24
2
1.4k
Live Update notificationのつかいどころ
chigichan24
0
350
不具合調査とTest
chigichan24
1
450
Flutterと難読化
chigichan24
0
5.7k
Building Android and looking into the Android System
chigichan24
2
4.2k
DroidKaigiカンファレンスアプリの歴史からみるアプリアーキテクチャのこれまでとこれから
chigichan24
2
3.5k
継続的に機能開発を進めながら行うマルチモジュール化
chigichan24
2
6.2k
Other Decks in Technology
See All in Technology
日本 Fintech 未来予測レポート 2027〜2028年(手動編集版)
8maki
0
1.7k
「エンジニア進化論」2028年の開発完全自動化、エンジニアはどう進化するか
cyberagentdevelopers
PRO
4
4.4k
中期計画、2回作ってみた ~業務委託と正社員、両方の視点から~
demaecan
1
660
2026TECHFRESH畢業分享會 - AI 時代的人生存檔點
line_developers_tw
PRO
0
760
やさしいA2A入門
minorun365
PRO
11
1.7k
AI駆動開発を通して感じた、 AI時代のデザイナーの役割変化
whisaiyo
0
230
Agent Skills設計で柔軟性と硬さのバランスが難しい話
nassy20
0
120
MIERUNE JCT 発表資料「宇宙から伊能忠敬ごっこ」
syuchimu
0
200
爆速でマルチプロダクトを立ち上げる時 事業・CTO目線で大事にしたい事
miyatakoji
0
100
Android の公式 Skill / Android skills
yanzm
0
120
就職⽀援サービスにおけるキャリアアドバイザーのシフトスケジューリング
recruitengineers
PRO
1
140
JSAI2026 オーガナイズドセッションOS-27「不動産とAI」趣旨説明 / JSAI2026 Organized Session OS-27 “Real Estate and AI”: Statement of Purpose
ykiyota
0
230
Featured
See All Featured
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
190
How Software Deployment tools have changed in the past 20 years
geshan
0
34k
ラッコキーワード サービス紹介資料
rakko
1
3.6M
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.7k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Navigating Algorithm Shifts & AI Overviews - #SMXNext
aleyda
1
1.3k
WENDY [Excerpt]
tessaabrams
11
38k
The agentic SEO stack - context over prompts
schlessera
0
810
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
840
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
Accessibility Awareness
sabderemane
1
140
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
Transcript
Application Design 勉強会 #2 Wed Jun 26 Kazuki Chigita
第7章 アジャイル設計
アジャイル開発の考え - アジャイル開発での全体像はソフトウェアと共に 展開していく. - 先を見越してデータベースの設計はしないし,将来の要求に 時間を掛けない. -
各イテレーションで「今」を最良の構造にし,常に「今」と同じ レベルの品質を保つ.
アジャイル設計ってなに? - アジャイル開発で用いる 設計 手法 - つまり,どういうソースコードであるべきかが 「設計」だ (著者談)
- なぜアジャイル設計をするのか? - ソフトウェアはアジャイル開発のイテレーションを 通して変化し続ける. - これに追従して設計をしないと「悪臭」がする. - 「悪臭」がすると,保守がしづらくなったり,機能追加に多大 な工数がかかったりする. UMLダイアグラムのような抽象 的に表現する技法での 設計ではなく,これを具体化した ソースコード自身のこと. だから,設計をしなければならない.
悪臭の例 1. 硬さ 変更しにくいシステム.1つの変更のためにそれと依存関係に あるモジュールが芋づる式に変更点があらわれること. 2. もろさ 1つの変更によって,概念的に関連のない箇所までもが壊れて しまうシステム.
3. 移植性のなさ 他のシステムで利用価値のある部分をモジュールとして切り出すことが 難しい状態. 4. 扱いにくさ ソフトウェアの扱いにくさ,開発環境の扱いにくさ. 5. 不必要な複雑さ 設計時に不必要な仕様を取り込んでいる(アジャイル開発の考えに反し ている) 6. 不必要な繰り返し 別モジュールからコピペしてきたものを含んでいる. 抽象化すべき. 7. 不透明さ わかりにくいモジュールが存在する状態.
何がソフトウェアを腐敗させるのか? - 仕様変更に追従できなくなったときにソフトウェアが 腐る. - 仕様変更に追従できない→設計に問題がある→ アジャイル開発に耐えうる設計やプラクティスを実践するべき -
アジャイルチームはソフトウェアの腐敗を許すな. - じゃあどうすれば?→クリーンな設計やプラクティスを実践す るべき. - クリーンな設計やプラクティスを以降の章で紹介.
第8章 単一責任の原則(SRP)
単一責任の原則 (SRP : Single Responsibility Principle) - SOLID原則の一角を成す. -
日本語での説明 - クラスを変更する理由は2つ以上存在してはならない - 本には1つ以上と書いてあるけど,多分違う.
Rectangleクラスの例 - Geometry applicationが演算処理のためにRectangleクラスを 参照する. - Graphical ApplicationはGUIへの描画のためにRectangleクラ スを参照する.
Geometry Application GUI Graphical Application Rectangle +draw() +area(): double
SRP違反の改善 - この状況下でのRectangleの役割 1. 数学的なモデルを提供する役割 2. GUIで四角形を塗りつぶす役割 - 悪臭シリーズでいうところの扱いにくさ
- Geometry applicationが不必要にGUIを含む構図に なっている. - GUI都合で表示するものが変わったときに無関係なGeometry Applicationも変更の必要が生まれる. - 解決策は,演算部分を切り出す(抽象化してinterfaceを切り出 す操作と言える) Geometry Application GUI Graphical Application Rectangle +draw() +area(): double
SRP違反の改善 Geometry Application GUI Graphical Application Rectangle +draw() +area(): double
Geometry Application GUI Graphical Application Rectangle +draw() Geometric Rectangle +area(): double
単一責任の原則の「責任」とはなにか? - 「責任 = 役割 = 変更理由」と定義している. - クラスの変更理由は1であるべき
<=> クラスの変更理由が2つ 以上ある場合そのクラスには2つ以上の役割がある.
単一責任の原則の適用を見極める - 役割が2つ以上あるときに分離するのが基本. - しかし,異なる役割ながら,必ず同時に変更が生じる役割は 分離する必要なない. <=> 複数の役割が結合する理由を持っている事がある.
- 過剰な適用は設計を不必要に複雑にする. - これは他の原則でも不必要な適用は良くない. - 「変更の理由が変更の理由たるのは,"実際に"変更の理由 が生じる場合だけ」
第9章 オープンクローズドの 原則
オープンクローズドの原則 (OCP : Open-Closed Principle) - 拡張に対して開かれている(Open) モジュールの振る舞いを拡張できる. 追加の仕様要求がきてもモジュールに新たな振る舞いを 追加することでその変更に対処できる.
- 修正に対して閉じている(Closed) モジュールの振る舞いを修正しても,そのモジュールの ソースコードやバイナリは影響をうけない. これはなんか矛盾している概念に見えるがなんとかなる.
client-serverの例 - Client,Serverともに具体的な実装を持っている. - Serverの実装が変更されるとClientも変更せざるを えない.(OCP違反) Client Server
解決策1 : 抽象を利用することでOCPを実現(Strategy pattern) - 依存部分をinterfaceとして切り出す. - server abstractにしない理由→抽象クラスはそれを実装す
る側より使う側のほうが関係が密接だから. - Serverの実装が変わってもClientは影響を受けない. Client <<interface>> Client Interface Server
解決策1 : 抽象を利用することでOCPを実現(Strategy pattern) - 依存部分をinterfaceとして切り出す. - server abstractにしない理由→抽象クラスはそれを実装す
る側より使う側のほうが関係が密接だから. - Serverの実装が変わってもClientは影響を受けない. Client <<interface>> Client Interface Server Piyo
解決策2 : 抽象を利用することでOCPを実現(Template Method Pattern) - Policyクラス(方針クラス)は具体的な実装を持っている(一つ 前のClientに対応). と同時に,抽象メソッドを持っている.(Client interfaceに対応)
- Policyクラスの抽象メソッドを実装する実装クラスが ある(Serverに対応) Policy + PolicyFunction() - ServiceFunction() Implementation - ServiceFunction()
OCPの実現 - Strategy Pattern , Template Method Patternが 典型的.
- 汎用的な機能と,その機能の具体的な実装を明確に 分離する役割を持つ. - 使い所 : 最も変更されるプログラム部分にだけ的を 絞って抽象化を適用するように務める (早まった抽象をしないことも抽象を使うのと同等に 重要なこと)
参考資料 - アジャイルソフトウェア開発の奥義 - ロバート・C・マーチン - pp. 103 - 141