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
DRY原則より「SOLID原則のS」
Search
お茶
June 18, 2025
Technology
0
42
DRY原則より「SOLID原則のS」
社内学生研修生向けのLTで発表した資料です
お茶
June 18, 2025
Tweet
Share
More Decks by お茶
See All by お茶
Denoのしょぼい使い方
okamonster
0
11
突然生えてきたシェーダー言語TSL
okamonster
0
10
なぜモダンな言語を学ぶか[2025/05/16 Progate Bar登壇]
okamonster
0
100
WebGLであそぼう! Three.jsについて
okamonster
0
30
クレカなしでもできる!Cloudflareではじめる金欠個人開発
okamonster
0
480
Other Decks in Technology
See All in Technology
Kiro のクレジットを使い切る!
otanikohei2023
0
110
Windows ネットワークを再確認する
murachiakira
PRO
0
260
組織のSREを推進するためのPlatform EngineeringとEKS / Platform Engineering and EKS to drive SRE in your organization
chmikata
0
180
白金鉱業Meetup_Vol.22_Orbital Senseを支える衛星画像のマルチモーダルエンベディングと地理空間のあいまい検索技術
brainpadpr
2
210
作るべきものと向き合う - ecspresso 8年間の開発史から学ぶ技術選定 / 技術選定con findy 2026
fujiwara3
7
2.1k
パネルディスカッション資料 (at Tableau Now! - 2026-02-26)
yoshitakaarakawa
0
1.1k
Introduction to Bill One Development Engineer
sansan33
PRO
0
380
Eight Engineering Unit 紹介資料
sansan33
PRO
1
6.9k
Data Hubグループ 紹介資料
sansan33
PRO
0
2.8k
生成AI活用によるPRレビュー改善の歩み
lycorptech_jp
PRO
5
2k
【SLO】"多様な期待値" と向き合ってみた
z63d
2
310
Contract One Engineering Unit 紹介資料
sansan33
PRO
0
14k
Featured
See All Featured
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
230
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
3.7k
Documentation Writing (for coders)
carmenintech
77
5.3k
Test your architecture with Archunit
thirion
1
2.2k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.3k
The Spectacular Lies of Maps
axbom
PRO
1
580
A better future with KSS
kneath
240
18k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
4 Signs Your Business is Dying
shpigford
187
22k
The B2B funnel & how to create a winning content strategy
katarinadahlin
PRO
1
290
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Music & Morning Musume
bryan
47
7.1k
Transcript
DRY原則より「SOLID原則のS」 2025/06/16 @ocha/Kazuki Okamoto
@makura_nageru https://お茶.dev お茶 / 岡本和輝(24) スーパーハムスター! ハム研メンター profile.json { “name”
: “お茶”, “hobby”: [“コーヒー”,”睡眠”], “zenn” : “https://zenn.dev/makura_nageru”, }
コードを書くのに慣れてくると... 「あれ??同じ処理書いてる気がする」 同じ処理は1個にまとめて使い回したろ 「DRY原則」 Don’t Repeat Yourself「同じことを何度も書くな」
これだけ先に覚えてしまうと... 例えば… 「税込価格を計算する処理」 「有料プラン10%値上げを計算する処理」 = 処理の内容自体は一緒
ここで... 政府 「爆減税します」 10% → 3%!!!!! 「有料プラン10%値上げ」 壊れる!!!!
なぜぶっ壊れたのか
原因 「2つの責務が違うものをロジックが同じという理由でまとめた」 「税込価格を計算する処理」 「10%値上げを計算する処理」 欲しい結果「税込価格」 登場人物は「税率」 変更時「税率が変わった時」 欲しい結果「値上げ後の価格」 登場人物は「値上げ率」 変更時「価格が変わった時」
文脈も欲しい結果も意味が全然違う… DRY原則はロジックの共通化ではなく意味の共通化
SOLID原則の「S」
SOLID原則 ソフトウェア設計時に従うべき5つの原則 S : Single responsibility principle(単一責任の原則) まずはこれだけ!!!! O :
Open/closed principle(オープン・クローズドの原則) L : Liskov substitution principle(リスコフの置換原則) I : Interface segregation principle(インターフェース分離の原則) D : Dependency inversion principle(依存関係逆転の原則)
単一責務の原則 「すべてのモジュールにおいて、それが持つ責務は1つとする」 言い換えると 「モジュールを変更する理由は1つだけにする」
今回の場合 ロジックが同じでも変更が必要になる理由が「2つ」ある 「税率」or「値上げ率」 が変わった時 単一責務の原則に違反している
なぜDRY原則より単一責務原則を推すか どちらも大切なことに変わりはない 「単一責務原則」・・・設計として守るべき原則(優先されるべき) 「DRY原則」 ・・・実装として守るべき原則 実装思想が設計思想を超えて破壊を生んではいけない
これからエンジニアになる皆さんへ SOLID原則のSは設計の基礎中の基礎 どのアーキテクチャの話をしても最後にはSの話になる 共通化の原則は同じロジックを共通化しようという訳ではない Sを意識できるようになったら「SOLID原則」を勉強してみて下さい! 今日から君も「単一責務の原則警察」だ!