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 勉強会 #4
Search
Kazuki Chigita
July 17, 2019
Technology
0
250
Application Design 勉強会 #4
Application Design 勉強会 #4
Kazuki Chigita
July 17, 2019
Tweet
Share
More Decks by Kazuki Chigita
See All by Kazuki Chigita
あの日のHotReloadはなぜ動かなかったのか? 〜OSセキュリティ(W^X)とJITコンパイラの攻防〜
chigichan24
3
880
「 動く」サンプルでスムーズなコミュニケーションを
chigichan24
1
800
Claude CodeでサクサクTestコードを移行しよう
chigichan24
2
1k
Live Update notificationのつかいどころ
chigichan24
0
280
不具合調査とTest
chigichan24
1
430
Flutterと難読化
chigichan24
0
5.5k
Building Android and looking into the Android System
chigichan24
2
4.2k
DroidKaigiカンファレンスアプリの歴史からみるアプリアーキテクチャのこれまでとこれから
chigichan24
2
3.5k
継続的に機能開発を進めながら行うマルチモジュール化
chigichan24
2
6.1k
Other Decks in Technology
See All in Technology
Why Organizations Fail: ノーベル経済学賞「国家はなぜ衰退するのか」から考えるアジャイル組織論
kawaguti
PRO
1
180
プロポーザルに込める段取り八分
shoheimitani
1
630
Agent Skils
dip_tech
PRO
0
130
StrandsとNeptuneを使ってナレッジグラフを構築する
yakumo
1
120
ランサムウェア対策としてのpnpm導入のススメ
ishikawa_satoru
0
220
Amazon S3 Vectorsを使って資格勉強用AIエージェントを構築してみた
usanchuu
4
460
Amazon Bedrock Knowledge Basesチャンキング解説!
aoinoguchi
0
160
Oracle Cloud Observability and Management Platform - OCI 運用監視サービス概要 -
oracle4engineer
PRO
2
14k
SRE Enabling戦記 - 急成長する組織にSREを浸透させる戦いの歴史
markie1009
0
170
Kiro IDEのドキュメントを全部読んだので地味だけどちょっと嬉しい機能を紹介する
khmoryz
0
210
SREじゃなかった僕らがenablingを通じて「SRE実践者」になるまでのリアル / SRE Kaigi 2026
aeonpeople
6
2.5k
AIエージェントを開発しよう!-AgentCore活用の勘所-
yukiogawa
0
190
Featured
See All Featured
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
120
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
170
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.6k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
60
42k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
1
1.3k
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
120
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
84
Building the Perfect Custom Keyboard
takai
2
690
Designing for Performance
lara
610
70k
Leading Effective Engineering Teams in the AI Era
addyosmani
9
1.6k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Joys of Absence: A Defence of Solitary Play
codingconduct
1
290
Transcript
Application Design勉強会 13-15章 Wed Jul 17 Kazuki Chigita
はじめに • 第3部の意義 • デザインパターンを学ぶ.
今⽇話すこと • Commandパターン • ActiveObjectパターン • TemplateMethodパターン • Strategyパターン •
Facadeパターン • Mediatorパターン
今⽇話すこと • Commandパターン • ActiveObjectパターン • TemplateMethodパターン • Strategyパターン •
Facadeパターン • Mediatorパターン
Commandパターン • 以下のようなinterfaceを用意する. • 利用するときはCommandを実装する. • 何がうれしいの? • この構造にすれば,Commandの実装クラスの詳細を 知らずとも利用できる.
• do()をすれば全てのコマンドが操作できる.
Commandパターン • 以下のようなinterfaceを用意する. • 利用するときはCommandを実装する. • 何がうれしいの? • この構造にすれば,Commandの実装クラスの詳細を 知らずとも利用できる.
• do()をすれば全てのコマンドが操作できる. シンプルなCommandパターンでは メソッドは⼀つ
Commandパターン • 以下のようなinterfaceを用意する. • 利用するときはCommandを実装する. • 何がうれしいの? • この構造にすれば,Commandの実装クラスの詳細を 知らずとも利用できる.
• do()をすれば全てのコマンドが操作できる. シンプルなCommandパターンでは メソッドは⼀つ それぞれでdo()をoverrideする.
Commandパターン(例1) • Transactionでの利用 • 使う側は同様にTransactionを実装(override) • メリット1 : ビジネスロジックとチェック機構の分離 •
メリット2 : 一時保存 / 時間差実行の実現
Commandパターン(例1) • メリット1 : ビジネスロジックとチェック機構の分離 • validate() はGUI等からも使われる有効性の チェックが具体的な登録処理を含むのは危ない. •
validate()はデータベースの詳細を知ることがな いので,ここでも分離ができている. • メリット2 : 一時保存 / 時間差実行の実現 • validate()の後,すぐにexecute()を呼び出す 必要はない. • execute()だけバッチ処理的に時間差で実行しても なんの問題もない. • 分離することで,一時的に状態を保持しておく構造 ができている.
Commandパターン(例2) • Undo機構の実現 • Commnadの実装先でdo()の処理内容を記憶す る必要がある. • undo()はdo()に依存しているので抱き合わせ て実装を考える必要がある.
Commandパターンまとめ • 普通はクラスに多くのpublic methodをもたせ るがそうではなくごく少数に抑えることで, 見通しを良くする. • interfaceの中に複数のメソッドを入れても,そ の存在意味を分離させたり(Transactionの例), 抱き合わせたり(Undoの例)できる.
今⽇話すこと • Commandパターン • ActiveObjectパターン • TemplateMethodパターン • Strategyパターン •
Facadeパターン • Mediatorパターン
ActiveObjectパターン • Commandパターンの利用例 • イベント駆動型やマルチスレッドを実現するた めのパターン ActiveObjectEngine : Commandのリストを持ち, これらの実⾏を管理する
Command : Interface.Commandパターン. SleepCommand: Commandの実装クラス
ActiveObjectパターン
ActiveObjectパターン ActiveObjectEngine itsCommands SleepComand HogeComand (wakeupCommandとして持っていると仮定)
ActiveObjectパターン ActiveObjectEngine itsCommands SleepComand HogeComand (wakeupCommandとして持っていると仮定)
ActiveObjectパターン ActiveObjectEngine itsCommands SleepComand SleepTimeの間これを繰り返す. HogeComand (wakeupCommandとして持っていると仮定)
ActiveObjectパターン ActiveObjectEngine itsCommands SleepComand SleepTimeの間これを繰り返す. HogeComand (wakeupCommandとして持っていると仮定) SleepTimeが終わったらこっちが登録される.
ActiveObjectパターン ActiveObjectEngine itsCommands SleepComand SleepTimeの間これを繰り返す. HogeComand (wakeupCommandとして持っていると仮定) SleepTimeが終わったらこっちが登録される.
ActiveObjectパターン
ActiveObjectパターンまとめ • 本来はブロッキング処理等で処理を止めて, itsCommandsを複数のスレッドにわたしてあ げると簡易的なマルチスレッド処理に実現がで きる. • イベント駆動型の真髄はこういうパターンだ. • Commandパターンをうまく活用している例.
今⽇話すこと • Commandパターン • ActiveObjectパターン • TemplateMethodパターン • Strategyパターン •
Facadeパターン • Mediatorパターン
TemplateMethodパターン • 課題 : 似た処理がアチラコチラに出てくる. パターン化した処理がコピペで煩雑に使われて いる. • 解決法 •
共通化や概念化できる大きな枠としての処理を abstract class(抽象基本クラス)に持っていく. • 上の概念化されたクラスを継承先で具体的なクラス 実装を行う. • 例 : Bubble Sortをどう扱うか
TemplateMethodパターン • BubbleSorter という abstractクラスを作成し, ここに大枠の実装の処理を委ねる. • これを継承するクラスで詳細を実装することで 共通化を図る. BubbbleSorter
{abbstract} IntBubbbleSorter DoubleBubbble Sorter
None
TemplateMethodパターン • 問題点 • BubbleSorterという名前にしてることからも分かる 通り,swap(index: Int)や, outOfOrder(index: Int)は,他のアルゴリズム で利用できない.
• BubbleSortのための再利用性はあるが, 他アルゴリズムのために使うことができない.
今⽇話すこと • Commandパターン • ActiveObjectパターン • TemplateMethodパターン • Strategyパターン •
Facadeパターン • Mediatorパターン
Strategyパターン • 課題 : 似た処理がアチラコチラに出てくる. パターン化した処理がコピペで煩雑に使われて いる.(TemplateMethodパターンと同じ) • 解決法 •
汎用的な部分や概念的な部分を抽象クラスで実装せ ずに,Handleクラスのようなものに持っていく • 実装すべきものはinterfaceに切り出す • 例 : Bubble Sortをどう扱うか
None
None
Strategyパターン • 良い点 • TemplateMethodパターンの課題を解決している. • SortHandleを他のソートパターンでも利用できる • interfaceで切り出しているので, DIPと相性がいい.
• BubbleSortのみにとどまらない再利用性が高い. • 問題点 • 実装が少し多くなる • (こういうパターンはStrategyパターンで解決 するのが現状良さそう)
今⽇話すこと • Commandパターン • ActiveObjectパターン • TemplateMethodパターン • Strategyパターン •
Facadeパターン • Mediatorパターン
Facade & Mediator パターン • 課題 : クラス間の結合度を下げたい. • 解決方法
• Façade • 上から抑える(wrapする) • Mediator • 下から抑える(Mediatorにやってもらう)
Facade & Mediator パターン • 課題 : クラス間の結合度を下げたい. • 解決方法
• Façade • 上から抑える(wrapする) • Mediator • 下から抑える(Mediatorにやってもらう)
Facadeの場合 P224 図15-1より
Facadeの場合 P224 図15-1より 集約点を作る
Mediatorの場合
Mediatorの場合
使い分け • FacadeとMediatorの使い分け • 明示的に方針を示したいとき.集約点を作りたいと き→Façade • 非明示的に方針を課したいとき→Mediator