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.
→
まりも
September 26, 2024
Programming
0
91
よい設計のプログラムを作るには
アジャイルが当然の時代になり、プログラムの作り方も変わってきています。昔と変わったところもあり、それでいて共通するところもあります。その変化について解説してみました。
まりも
September 26, 2024
Tweet
Share
More Decks by まりも
See All by まりも
メンタルモデルから見るオブジェクト設計
hrmstrsmgs
0
250
技術的負債
hrmstrsmgs
0
280
歴史から理解するJavaScript
hrmstrsmgs
0
76
論理的な考え方
hrmstrsmgs
0
77
論理的な話し合いはなぜ必要か
hrmstrsmgs
0
50
腕のある技術者はなぜ
hrmstrsmgs
0
100
疑似乱数の生成
hrmstrsmgs
0
51
構造化プログラミング
hrmstrsmgs
0
170
社内勉強会の戦略
hrmstrsmgs
0
68
Other Decks in Programming
See All in Programming
年間50登壇、単著出版、雑誌寄稿、Podcast出演、YouTube、CM、カンファレンス主催……全部やってみたので面白さ等を比較してみよう / I’ve tried them all, so let’s compare how interesting they are.
nrslib
3
260
Codexに役割を持たせる 他のAIエージェントと組み合わせる実務Tips
o8n
4
1.4k
Mastering Event Sourcing: Your Parents Holidayed in Yugoslavia
super_marek
0
130
RailsのValidatesをSwift Macrosで再現してみた
hokuron
0
140
今年もTECHSCOREブログを書き続けます!
hiraoku101
0
200
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimization Driven by Telemetry Signals
seike460
PRO
2
200
2026-03-27 #terminalnight 変数展開とコマンド展開でターミナル作業をスマートにする方法
masasuzu
0
250
Xdebug と IDE による デバッグ実行の仕組みを見る / Exploring-How-Debugging-Works-with-Xdebug-and-an-IDE
shin1x1
0
270
ローカルで稼働するAI エージェントを超えて / beyond-local-ai-agents
gawa
1
190
Goの型安全性で実現する複数プロダクトの権限管理
ishikawa_pro
2
1.4k
20260320登壇資料
pharct
0
140
Reactive ❤️ Loom: A Forbidden Love Story
franz1981
2
200
Featured
See All Featured
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.3k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.1k
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
0
250
Java REST API Framework Comparison - PWX 2021
mraible
34
9.2k
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
240
What does AI have to do with Human Rights?
axbom
PRO
1
2.1k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
93
30 Presentation Tips
portentint
PRO
1
260
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.8k
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
110
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Transcript
良い設計のプログラムを作 るには アジャイル時代に必要とされる設計
アジャイルの時代
アジャイル時代に必要とされる設計 目指すところはそんなに変 わらないですけどね。
アジャイル時代に必要とされる設計 ただ途中経過は結構違っ ているかもしれない。
アジャイルでプログラムはどう変わったか 少々の手戻りはどんとこい 変更はいつでも修正できる
アジャイルでプログラムはどう変わったか そもそも理想的な設計は 一つに決まらない
アジャイルでプログラムはどう変わったか 機能が変更されれば最適な設計も変わる
アジャイルでプログラムはどう変わったか テスト駆動開発では、内部 設計はリファクタリング時 に行う。 常にゴールが変 わる中で、常に 最適を保つ。
設計方針
DRY DRY Don't repeat yourself 絶対に二度書かない
DRY 本当に同じこ とは絶対に二 度書くな! 別に2回書く のが面倒だか らじゃないか ら。 影響範囲調べ る必要がない
コートにする。
DRY 厳密に絶対かと言えばさすがにそうじゃないけど。 たまたま同じ書き方になっているだけで違う意味の場合。 どう工夫してもその言語では絶対共通化できない場合。 無理やり共通化したほうが明らかに読みにくくなっている場合。
YAGNI YAGNI You ain't gonna need it いずれ必要にならない
YAGNI 必要にならなくても存在する以上は必ずコストがかかる。 必要になった時に当初想像していた仕様で問題ないことは少ない。 後で追加がよほど面倒な時はさすがに話が別だが。
オブジェクト指向設計 昔からの「正しい設 計」に近づけていく
抽象化 人間に対してプログラムを書く char*ではなく string型を使う “YYYYMMDD”では なくDate型を使う
識別子には適切な名前を付ける 解読しやすい 読めば分かるので解読する必要もない numberOfPeopleOnTheUSOlympicTeam maximumNumberOfPointsInModernOlympics checkTotal currentDate linesPerPage
識別子には適切な名前を付ける 辞書や類語辞典を使う 語順は正しい文法で 現在分詞や過去分詞をつかう 手を抜くな!!
推敲 門を推すというか敲くというか一晩考える。 もちろん文法は全部使えるのが当然です。 日本語の文章を推敲するのと全く同じ作業。