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
Is High Quality Software Worth the Cost?
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
hideki kinjyo
PRO
August 23, 2019
Programming
1.1k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Is High Quality Software Worth the Cost?
https://martinfowler.com/articles/is-quality-worth-cost.html
が興味深かったので、社内LTで紹介してみました
hideki kinjyo
PRO
August 23, 2019
More Decks by hideki kinjyo
See All by hideki kinjyo
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
260
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
260
ソースコード→AST→オペコード、の旅を覗いてみる
o0h
PRO
1
180
PCOVから学ぶコードカバレッジ #phpcon_odawara
o0h
PRO
0
380
夢の無限スパゲッティ製造機 -実装篇- #phpstudy
o0h
PRO
0
250
夢の無限スパゲッティ製造機 #phperkaigi
o0h
PRO
0
920
PHPer Book Revue 「雑に作る」 #phperkaigi
o0h
PRO
0
380
俺にも私がAIと作った オススメの個人ツールを語らせてくれ
o0h
PRO
0
78
#phperbiglt のLT
o0h
PRO
0
110
Other Decks in Programming
See All in Programming
トークンをケチるな、設計しろ:GitHub Copilotを賢く使うコンテキスト戦略
ochtum
0
150
技術的負債解消で開発者の未来を開く- AIの力でコード刷新
kmd2kmd
0
110
New "Type" system on PicoRuby
pocke
1
1k
JavaDoc 再入門
nagise
1
410
Dataformのリポジトリを立ち上げるときにまずやること / dataform-day0-2026
snhryt
0
180
そのテスト、説明できますか?~LWテスト戦略FW~のご紹介
nakahara
0
160
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
7.6k
並列実装の現場、2ヶ月間実務でAIを使い倒したAIもPCも私も限界が近い
ming_ayami
0
130
AI 輔助遺留系統現代化的經驗分享
jame2408
1
960
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
220
ローカルLLMでどこまでコードが書けるか -拡張版 / How much code can be written on a local LLM Extended
kishida
12
4.4k
RTSPクライアントを自作してみた話
simotin13
0
630
Featured
See All Featured
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
10k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
10
1.2k
HDC tutorial
michielstock
2
720
Deep Space Network (abreviated)
tonyrice
0
210
Done Done
chrislema
186
16k
Art, The Web, and Tiny UX
lynnandtonic
304
22k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
170
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Abbi's Birthday
coloredviolet
3
8.2k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.5k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Transcript
Is High Quality Software Worth the Cost? ブログ記事読みました!ファンです!!LT(社内)
https://twitter.com/t_wada/status/ 1155691342560808965
Martin Fowler⽒のエントリーを読んだ話をします https://martinfowler.com/articles/is-quality-worth-cost.html
この話の議論と結論 • 議論: • 「質の⾼いコード」を書こうとすると、コスト掛かるよね • 実際の現場では時間が⾜りないよ! • 結論: •
「よくないコード」は、ソフトの成⻑に従い⽣産性の低下を招く • 「よいコード」は、⽣産性を寧ろ向上させる • 優れたチームはコードの品質を気にしているよ!
こんにちは!
皆さん! クオリティを⼈質にとっていますか? http://shirobako-anime.com/story/21.html
お話の前に・・ • 今回「クオリティ」といったら、 「コードの品質」のことだと思ってください • External Quality: UIとか安定性とか • Internal
Quality: アーキテクチャ、設計 ➡ External Qualityは顧客から⾒える部分、 Internal Qualityは開発者しか⾒えない部分 ͬͪ͜Ͷʂ
レベッカと私(例えば) • レベッカと私は、似たようなアプリを作ってい ます • UI的にも提供体験的にも、今は似たようなレベ ルです • レベッカは$10!わたしのは$6 Ͳ͕ͬͪ
΄͍͠Ͱ͔͢ʁ
レベッカと私(例えば) • もう1点、実は違いがあります! • レベッカのアプリは、アーキテクチャもしっ かりしていて読みやすいです! • 私のアプリは・・・まぁ動くんでぇ〜 Ͳ͕ͬͪ ΄͍͠Ͱ͔͢ʁ
レベッカと私(例えば) • UI、提供体験: External Quality • ソースコードのレベル: Internal Quality •
Internal Qualityに価値を感じ、⽀払う⼈はいない ➡ それが Is High Quality Software Worth the Cost? という議論をもたらす
なぜ 開発者は「クオリティ」を 考えるべきなのか
ソフトウェア開発って • 「ソース」に継ぎ⾜し継ぎ⾜し、やっていく ものですよね • よく「建築」とかに例えられるけど、 その点において決定的に違いますわな
例えば「新規」機能の追加 • まず既存コードやドキュメントを読むでしょ • その上で「⾃分が追加する機能」を どう差し込むか?を考えるでしょ • 実際に「そのために適したI/F」とか「データ構 造」を考えるでしょ •
さぁ〜て書くかー!
ソフトウェア開発 ≒「読み解く」作業が⼤半
例えば「新規」機能の追加 • まず既存コードやドキュメントを読むでしょ • その上で「⾃分が追加する機能」を どう差し込むか?を考えるでしょ • 実際に「そのために適したI/F」とか「データ構 造」を考えるでしょ •
さぁ〜て書くかー! ͜ΕΒ͕શͯɺ ʮطଘίʔυʯͷ ӨڹԼʹ͋Δ࡞ۀ
読まにゃらなんのですが・・ • もつれにもつれたロジック、フロー • 意味不明な変数名 • 巨⼤で関係ないデータ、取り出しにくい構造 • 分割されていないモジュール
クオリティが低いと • 該当コードを探し出すのに時間がかかり・・・ • その内部処理を読み解くのに時間がかかり・・・ • 既存コードに影響を与えない修正に時間がかかり・・・ • (それでもバグを出しやすくて)・・・ •
もしエンバグしたら、「追加作業」で時間がかかり・・・ • デバッグしてコードを理解するのには時間がかかり・・・ • 原因究明後に「正しい修正」をするのに時間がかかり・・・
クオリティが低いと • 該当コードを探し出すのに時間がかかり・・・ • その内部処理を読み解くのに時間がかかり・・・ • 既存コードに影響を与えない修正に時間がかかり・・・ • (それでもバグを出しやすくて)・・・ •
もしエンバグしたら、「追加作業」で時間がかかり・・・ • デバッグしてコードを理解するのには時間がかかり・・・ • 原因究明後に「正しい修正」をするのに時間がかかり・・・ ᶃ ࣮Ͱ࣌ؒ͘͏͠ ᶄ ͔͚࣌ؒͯ ʮବʯ͕ͪͩ͠ ᶅ ᶃͰ͔͔ͬͨ࣌ؒBHBJO
クオリティが低い事で負のサイクルに。 その負は、更に次の負を呼び込み、 どんどん加速していく・・・・
その後のレベッカと私(例えば) • レベッカは継続的に新機能を提供していきました • 私は・・・ ちょっとした機能修正ですら迂闊に⼿を出せない 状況に。 • ユーザーがどちらを選択するかは⾃明。 レベッカは更に競争⼒を増し(もっと価格上げても
⼤丈夫かも!)、私は撤退を余儀なく・・・
開発スピードと クオリティへの(投資)の関係
࣮͞Εͨྦྷܭػೳ 1+ͷ׆ಈظؒ 「コードが成⻑していったときに、いじるのが どのくらい⼤変か?」を⽰した概念図
࣮͞Εͨྦྷܭػೳ 1+ͷ׆ಈظؒ 最初は「低クオリティ」がスピードに乗ってい るようにみえる
࣮͞Εͨྦྷܭػೳ 1+ͷ׆ಈظؒ 中⻑期的には、低クオリティのPJは成⻑が鈍化し ている。⼀⽅で⾼クオリティのPJは⽣産性が失わ れない
࣮͞Εͨྦྷܭػೳ 1+ͷ׆ಈظؒ 「クオリティを捨てて得られるリード」が⽣じて いるのは、本当に⼀瞬・・・”意外と”すぐ追いつ かれる。
低クオリティvs⾼クオリティ • 低クオリティのコードは、未来のメンバーの 「やらなければいけないことを増やす」。 • 読む苦労、エンバグするリスク • ⾼クオリティのコードは、未来のメンバーの 「やりたいことを⼿助けする」。 •
先⾏したコードを活⽤できる! ෆຯ͍ɺߴ͍ɺ͍ ඒຯ͍ɺ͍҆ɺૣ͍
よいチーム、悪いチーム
どんなチームでも • 「品質に気を遣っていこうな!」は⼤事 • が、優秀なチームが気をつけていたとしても 「嫌なコード(cruft)」は⽣まれちゃう • そこで放ったらかしにしないのが良いチーム! • それが「成⻑速度を維持する」のにつながる
キッチンの⽐喩 • キッチンが汚れてるまま、料理ってできる? • 気持ちよくないよね・・ • それでも放ったらかしていると・・ • 汚れが乾いてこびり付き、掃除⼤変! •
次の料理も引き続き嫌な気分!!
まとめ
None
めっちゃ便利だった・・ https://qiita.com/wtetsu/items/c43232c6c44918e977c9