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
しが あきとし(AkitoShiga)
August 17, 2024
Programming
3
420
ケント・ベックに学ぶ『良いコード』の書き方
『良いコード』というテーマに対して自分がケント・ベックから学んだことをまとめました
しが あきとし(AkitoShiga)
August 17, 2024
Tweet
Share
More Decks by しが あきとし(AkitoShiga)
See All by しが あきとし(AkitoShiga)
テスト駆動開発✅️
akitoshiga
1
610
Other Decks in Programming
See All in Programming
Honoとフロントエンドの 型安全性について
yodaka
7
1.3k
楽しく向き合う例外対応
okutsu
0
150
データの整合性を保つ非同期処理アーキテクチャパターン / Async Architecture Patterns
mokuo
48
17k
苦しいTiDBへの移行を乗り越えて快適な運用を目指す
leveragestech
0
640
お前もAI鬼にならないか?👹Bolt & Cursor & Supabase & Vercelで人間をやめるぞ、ジョジョー!👺
taishiyade
6
4k
Multi Step Form, Decentralized Autonomous Organization
pumpkiinbell
1
750
Flutter × Firebase Genkit で加速する生成 AI アプリ開発
coborinai
0
160
PHPカンファレンス名古屋2025 タスク分解の試行錯誤〜レビュー負荷を下げるために〜
soichi
1
210
なぜイベント駆動が必要なのか - CQRS/ESで解く複雑系システムの課題 -
j5ik2o
12
4.1k
sappoRo.R #12 初心者セッション
kosugitti
0
260
Writing documentation can be fun with plugin system
okuramasafumi
0
120
Amazon Bedrock Multi Agentsを試してきた
tm2
1
290
Featured
See All Featured
Producing Creativity
orderedlist
PRO
344
39k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
49
2.3k
Product Roadmaps are Hard
iamctodd
PRO
50
11k
Bootstrapping a Software Product
garrettdimon
PRO
306
110k
Fontdeck: Realign not Redesign
paulrobertlloyd
83
5.4k
Writing Fast Ruby
sferik
628
61k
Testing 201, or: Great Expectations
jmmastey
42
7.2k
The Straight Up "How To Draw Better" Workshop
denniskardys
232
140k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
656
59k
Keith and Marios Guide to Fast Websites
keithpitt
411
22k
Building Applications with DynamoDB
mza
93
6.2k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
21
2.5k
Transcript
ケント・ベックに学ぶ 『良いコード』の書き方 2024.08.17 Kansai Dev Garage しが あきとし
自己紹介 • なまえ ◦ しが あきとし(@akitoshiga) • 普段何してる? ◦
医療系HR企業のWebエンジニア ◦ 主にRuby on Railsアプリの開発 • 好きなプログラマー ◦ ロバート・C・マーティン ◦ ケント・ベック
目次 1. ケント・ベックについて 2. ケント・ベックの『良いコード』 3. パターン 4. パターンの具体例
5. まとめ
1. ケント・ベックについて
ケントベックとは 1. ケント・ベックについて • プログラマー • アジャイル開発におけるエクスト リーム・プログラミング(XP)の考案 者 •
テスト駆動開発(TDD)の第一人者と しても有名 • 代表的な著書 ◦ 「エクストリームプログラミング」 ◦ 「テスト駆動開発」
なぜケント・ベックから学ぶのか?
ケント・ベックの『良いコード』に対する熱量がすごい 1. ケント・ベックについて 『 70年の人生は、20億秒を少し超えるに過ぎない。誇りの持てない仕事で無駄にする時 間はない。良いコードを書くこと自体が喜びであり、そのコードを他の人が理解し、評価 し、使用し、拡張してくれればさらに喜びは増す。 』 ケント・ベック「実装パターン」より引用
ケントベックの凄いところ 1. ケント・ベックについて • 職業人生を捧げるほどの『良いコード』に対する熱量 • コーディングに対する深い洞察 • 後述する『パターン』を用いてコーディングにおける個々の課題とその解決方法を抽 象化して再利用可能にするアプローチを推進した
2. ケント・ベックの『良いコード』
ケント・ベックの考える『良いコード』とは? 2. ケント・ベックの『良いコード』 『 70年の人生は、20億秒を少し超えるに過ぎない。誇りの持てない仕事で無駄にする時 間はない。良いコードを書くこと自体が喜びであり、そのコードを他の人が理解し、評価 し、使用し、拡張してくれればさらに喜びは増す。 』 ケント・ベック「実装パターン」より引用
コミュニケーション・シンプル・柔軟性
コミュニケーション・シンプル・柔軟性 2. ケント・ベックの『良いコード』 『 卓越したプログラミングにおいて必要とされる価値は、コミュニケーション、シンプル、 柔軟性である。これらの価値は互いに衝突するときもあるが、補完し合うことの方が多 い、拡張方法が数多く存在し、余分な要素が存在せず、読みやすく、理解しやすいのが 最高のプログラムだ。 』 ケント・ベック「実装パターン」より引用
コミュニケーション 2. ケント・ベックの『良いコード』 • 読み手が理解できるコード • 実装意図を正しく伝えらえるコード • 人間とコミュニケーションができるコードは保守のコストを大きく減らすことができる ◦
コードは書いた時間より読まれる時間の方が長い • ケント・ベックは開発をコードと人間のコミュニケーションと捉えた
シンプル 2. ケント・ベックの『良いコード』 • 『余分な複雑性』のないコード • 『余分な複雑性』とは ◦ 動作に影響のないコード ◦
一生懸命動かそうとした痕跡のあるコード ◦ メンテナンス(リファクタ)されていないコード • 複雑なコード全てが悪というわけではない ◦ 解決すべき問題が複雑な場合はその複雑さが反映される →『本質的な複雑さ』 ◦ プログラミングには複雑さの玉と石を分ける作業が必要 • 何をシンプルとするかは個人による所がある ◦ ベテランにとってのシンプルは、初心者には難しすぎることも ◦ 読み手を意識した時に良いプログラムは生まれる
柔軟性 2. ケント・ベックの『良いコード』 • 変更を容易に行えるコード • 柔軟性は非効率なコードや設計を正当化するために悪用されがちなので注意 ◦ プログラムが柔軟であるべきなのは、プログラムがその方向に変更される場合だけ ◦
明日必要と思われた柔軟性すら必要とされない場合が多い • 凝った設計から得られる柔軟性よりも、シンプルと包括的なテストから得られる柔軟 性の方が効果的 • 「YAGNI」・「KISS」の原則を尊重する ◦ YAGNI →「You Ain’t Gonna Need It」 ◦ KISS →「Keep It Simple, Stupid」
これらの要素にケント・ベックは どうアプローチしたのか?
3. パターン
パターンについて 3. パターン • ソフトウェア設計上の課題とその有効な解決策を再利用可能なように一般化したも の ◦ 例 GoFのデザインパターン •
ケント・ベックはこのパターンの先駆け ◦ 1987年のOOPSLAで 「Using Pattern Languages for Object-Oriented Programs」を発表 • ケント・ベックはパターンを用いて『良いコード』を書くことを推進した
ケント・ベックの用いるパターンの特徴 3. パターン • 粒度が細かく幅広い ◦ ケント・ベックは多くのパターンを組み合わせてプログラミングをした ◦ クラスやメソッドの命名までにもパターンの考え方を取り入れている •
どのパターンも必ずコミュニケーション・シンプル・柔軟性のいずれかの価値を反映 している • どのパターンも以下の6つの原則に従っている 1. 結果の局所化 2. 繰り返しの最小化 3. 対称性 4. ロジックとデータの一体化 5. 宣言型の表現 6. 変更頻度
4. パターンの具体例
注意 4. パターンの具体例 • 以降のパターンは全てRubyで書いています • Rubyに馴染みがない人向けに一般的なイディオムからは外れた書き方をしている 部分があります
パターン1. Composed Method
パターン1. Composed Method 4. パターンの具体例 Before After
パターン1. Composed Method 4. パターンの具体例 • プログラムを一つの事のみにするメソッドに 分割する • メソッド内部のメッセージは
同じ抽象度になる ようにする • メソッド内部の対称性が保たれ、かつ宣言型 で意図が表現されるため読みやすく、意図が 伝わりやすくなる • Beforeではメソッドの処理を追わなければな らないが、Afterではメソッドの呼び出しを見る だけで何をやっているかわかるようになる
パターン2. Double Dispatch
パターン2. Double Dispatch 4. パターンの具体例 Before After
2. Double Dispatch 4. パターンの具体例 • オブジェクト指向的なパターン • 異なる2つの関心事の変更頻度を分割 •
多態性を用いて冗長な 『余分な複雑性』の排 除
パターン3. Method Object
パターン3. Method Object 4. パターンの具体例 Before After
パターン3. Method Object 4. パターンの具体例 • Composed Methodでも単純化できないほど メソッドが大きい場合は、そのメソッド自体を オブジェクトにしてしまう
• 関連するデータをプロパティとして持つことで ロジックとデータを一体化 する • 多くの引数を持つ場合は、メソッドから引数が なくなることで可読性も向上する • Composed Methodと組み合わせて使うこと でより明確でシンプルなコードになる
5. まとめ
まとめ 5. まとめ • ケント・ベックの考える『良いコード』はコミュニケーション・シンプル・柔軟性から成り 立つ • パターンを積極的に再利用し、効率的で的確なコーディングを行っている • ケントベックのパターンは6つの原則に従っている
◦ 結果の局所化・繰り返しの最小化・対称性 ◦ ロジックとデータの一体化・宣言型の表現・変更頻度 • 本日紹介したパターンやその他のパターンを学んだり、普段コーディングを行う中で パターンを発見することは良いコードを書くことに繋がっていく • 普段コードを書く中でパターンの6つの原則を意識するのも効果的
ご清聴ありがとうございました
Appendix パターンが従う6つの原則
本編で割愛したパターンが従う6つの原則について紹介 Appendix パターンが従う6つの原則 1. 結果の局所化 2. 繰り返しの最小化 3. 対称性 4.
ロジックとデータの一体化 5. 宣言型の表現 6. 変更頻度
原則1. 結果の局所化 Appendix パターンが従う6つの原則 • コードの変更の結果が一箇所に留まるようにコードを構成すること • コードの変更が想定外の場所に影響するとその変更コストは劇的に上昇する • 結果の局所化ができているコードであれば、コード全体を把握しなくても段階的に
理解すれば良くなる
原則2. 繰り返しの最小化 Appendix パターンが従う6つの原則 • 同じ目的の下に同じ処理を行うコードは一箇所にまとめて共通化すること • (当たり前だけど)コードが重複していると一つを変更すると他のすべても変更しな ければいけなくなる ◦
重複したコードの分だけ変更コストは増大する • ただし、必ずしも重複を排除すれば良いのではなく、目的が異なれば同じ処理で あってもコードは共通化しない方が良い ◦ 参考「クソコード動画『カプセル化 Mk-II』で考える、上手くカプセル化できない理由 ミノ駆動 @MinoDriven #ooc_2024」
原則3. 対称性 Appendix パターンが従う6つの原則 • 対称性を意識するとコードは劇的に読みやすくなる • コードの粒度や行える操作を対称的にする ◦ クラス内のプロパティの生存期間を同一にする
◦ あるメソッドのグループがあれば全て同じ引数を取るようにする ◦ 長い処理のメソッドを均一の粒度に分割する ◦ etc…
原則4. ロジックとデータの一体化 Appendix パターンが従う6つの原則 • ロジックとそのロジックが操作するデータは近くに置くこと • 結果の局所化を順守すると必然的にロジックとデータは一体化する • 関連するロジックとデータは同じタイミングで変更することが多くなる
◦ これらが同じ場所にあれば変更の結果も局所化が保たれる • ただし、ロジックとデータをどこに置くべきかは最初から明確ではない場合がある ◦ コードに対する継続的な責務の見直しは大事だなというのが個人的な所感
原則5. 宣言型の表現 Appendix パターンが従う6つの原則 • 実装の詳細を書くよりこの処理が何をするかという意図を宣言する ◦ JavaScriptを例にすると、for文よりforEachメソッド ◦ Javaを例にすると、for文よりStream
• 命令型のプログラミングは制御とデータのフローを頭の中でイメージしながら読む 必要がある • 宣言型で表現されていれば読み手の認知負荷を大幅に抑えられる
原則6. 変更頻度 Appendix パターンが従う6つの原則 • 変更されるタイミングが異なるロジックやデータは分けておく • 変更されるタイミングが同じロジックやデータは同じ場所に置いておく • クラス内のプロパティはなるべく一緒のタイミングで変更されるべき
◦ あるメソッドの実行中にだけ変更されるプロパティは、プロパティにせずローカル変数にすべき • 税額計算のソフトウェアを例にすると... ◦ 一般的な計算ロジックのコードと、年ごとに固有なコードは一緒にせず分けておく