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
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
natacon
April 19, 2023
Programming
540
0
Share
契約による設計の「契約」とは何を指しているか
natacon
April 19, 2023
More Decks by natacon
See All by natacon
"個"の集まりに"チームというフィクション"をデザインしてみた ― 認知とつながりが変わると、アウトカムの捉え方も変わる ―
natacon
0
110
Backend LT フェーズ変化、プロダクトの成長に伴う技術的変遷
natacon
0
170
課題解決ではなく、価値創造を求めるVoicyの開発チームの組織設計と立ち上げの勘所
natacon
5
1.7k
DDDにどう立ち向かう?リファクタリングのあれこれ
natacon
1
1.2k
DDD導入にどう立ち向かう? 開発現場への適用方法あれこれ②
natacon
1
510
DDD導入にどう立ち向かう? 開発現場への適用方法あれこれ①
natacon
1
410
Other Decks in Programming
See All in Programming
Kubernetes上でAgentを動かすための最新動向と押さえるべき概念まとめ
sotamaki0421
2
370
年間50登壇、単著出版、雑誌寄稿、Podcast出演、YouTube、CM、カンファレンス主催……全部やってみたので面白さ等を比較してみよう / I’ve tried them all, so let’s compare how interesting they are.
nrslib
4
690
Going Multiplatform with Your Android App (Android Makers 2026)
zsmb
1
270
ローカルで稼働するAI エージェントを超えて / beyond-local-ai-agents
gawa
1
240
AWS re:Invent 2025の少し振り返り + DevOps AgentとBacklogを連携させてみた
satoshi256kbyte
2
140
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimization Driven by Telemetry Signals
seike460
PRO
2
210
SkillがSkillを生む:QA観点出しを自動化した
sontixyou
5
2.4k
AI時代のシステム設計:ドメインモデルで変更しやすさを守る設計戦略
masuda220
PRO
7
1.2k
Ruby and LLM Ecosystem 2nd
koic
1
1.5k
ポーリング処理廃止によるイベント駆動アーキテクチャへの移行
seitarof
3
1.3k
Go_College_最終発表資料__外部公開用_.pdf
xe_pc23
0
120
存在論的プログラミング: 時間と存在を記述する
koriym
5
770
Featured
See All Featured
Become a Pro
speakerdeck
PRO
31
5.9k
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
410
Conquering PDFs: document understanding beyond plain text
inesmontani
PRO
4
2.6k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
170
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
140
Music & Morning Musume
bryan
47
7.1k
Joys of Absence: A Defence of Solitary Play
codingconduct
1
330
Bash Introduction
62gerente
615
210k
Information Architects: The Missing Link in Design Systems
soysaucechin
0
860
Exploring anti-patterns in Rails
aemeredith
3
310
Practical Orchestrator
shlominoach
191
11k
Transcript
契約による設計の「契約」とは 何を指しているか 2023/04/18 株式会社Voicy 灘脇裕一 (@natacoon) Voicy Tech Bar
自己紹介 灘脇 裕一 Backend Engineer 機能開発チームリーダー スクラムマスター 2012.04 - HRTech
2020.07 - Voicy 本日はよろしくお願いします! @natacoon 好きなモノ: 服とねことスプラトゥーン 株式会社Voicy
本日のアジェンダ 事前条件と事後条件の関係 1 2 契約による設計とは?
契約による設計とは?
契約による設計とは?
契約による設計とは? Wikiより 「契約による設計」(DbC)における 中心的な概念は、クライアントとサプ ライヤの契約 (contract) である。
契約による設計とは? キーワード - 事前条件(preconditions) - 事後条件(postconditions) - 不変条件(class invariant)
契約による設計とは? 今日の焦点 - 事前条件(preconditions) - 事後条件(postconditions) - 不変条件(class invariant)
契約による設計とは? 事前条件 関数の引数が適切であることを保証し、バグや予期しない動作を未然に防ぐため に、関数が呼び出される前に守らないといけない条件のこと。
契約による設計とは? 事前条件 大抵の場合、関数の最初で引数の値を検 証する。 コンストラクタ(またはそれに該当する もの)で検証することが多い。 条件に違反する場合はエラーを返す。
契約による設計とは? 事前条件 恩恵として - 入力の不備による正しくないインスタンスが出来上がってしまうことを未 然に防ぐことができる。 - ドメイン上で定義される正しい状態のインスタンスのみを作れることを保 証できる。
契約による設計とは? 事後条件 関数やクラスが呼び出された後に満たすべき状態を指定し、使われる側が、使う側 に対してこれだけは必ず守りますよということを示します。
契約による設計とは? 事後条件 関数やクラスを抜けるときに、返却値に 対して守られていなければならない状態 を確認する。 条件に違反する場合はエラーを返す。
事前条件と事後条件の関係
事前条件と事後条件の関係 雑に言うと 「呼び出し側が事前条件を満たしてくれるなら、事後条件を満たす状態を実現するこ とを約束するよ」 ということ
事前条件と事後条件の関係 なんらかのやりとりにおいて事前条件と事後条件を定義するということそのものに対 して「契約」という言葉を使っている 置き換えてイメージすると、顧客と提供者の関係において「こういうようにしてくれ るなら、こうするよ」ってことを約束(契約)する感じ。 Client Supplier 事前条件を守る 事後条件を守る
事前条件と事後条件の関係 なんらかのやりとりにおいて事前条件と事後条件を定義するということそのものに対 して「契約」という言葉を使っている 置き換えてイメージすると、顧客と提供者の関係において「こういうようにしてくれ るなら、こうするよ」ってことを約束(契約)する感じ。 Client Supplier 事前条件を守る 事後条件を守る 約束してる(契約してる)
まとめ - 使う側と使われる側での取り決めに対して「契約」という言葉を使っている - 契約を守れないなら、Fail Fastしよう - 事後条件が守られるのは事前条件が満たされているという前提に立っている - 事前条件が守られていなければ事後条件は守られず、表明(検証)する意
味がなくなってしまうため、その場合は関数やクラスの事前条件とセット で見直しましょう
お知らせ Meetyでカジュアル面談をやってます! 転職関係ない話もウェルカムなのでお話しましょう
お知らせ VoicyでエンジニアのVoicyのエンジニアメンバーが テックニュースや日々の活動をお届けしています! 私は水曜日に配信しています💡