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
2025-03-26 社内勉強会 オブジェクト指向入門 第二部 / Introduction ...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Kentaro Abe
March 26, 2025
Programming
57
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
2025-03-26 社内勉強会 オブジェクト指向入門 第二部 / Introduction to Object-Oriented Part2
Kentaro Abe
March 26, 2025
More Decks by Kentaro Abe
See All by Kentaro Abe
2025-08-27 社内勉強会 ソフトウェアテストの基礎 / Basics of Software Testing
abekem
0
31
2025-08-06 社内勉強会 Gitを知る頃 / When You First Know Git
abekem
0
63
2025-07-02 社内勉強会 SQLに親しむ / Getting to Know SQL
abekem
0
71
2025-05-28 社内勉強会 SOLID原則ではじめるよりよい設計の第一歩 / The First Step to Better Software Design with SOLID Principles
abekem
0
110
2025-04-23 社内勉強会 デザインパターン概論 / Overview of Design Patterns
abekem
0
66
SAP Event Meshで始めるイベント・ドリブン・アーキテクチャ / Getting Started with Event-Driven Architecture Using SAP Event Mesh
abekem
0
200
2025-02-27 社内勉強会 オブジェクト指向入門 / Introduction to Object-Oriented
abekem
0
110
Other Decks in Programming
See All in Programming
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
メソッドのジェネリクスでGoの夢は広がるか? / Kyoto.go #65
utgwkk
3
750
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
190
脅威をエンジニアリングの糧にして――現場編 / Turning Threats into Engineering Fuel — Field Edition
nrslib
0
280
CSC307 Lecture 17
javiergs
PRO
0
320
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
160
The NotImplementedError Problem in Ruby
koic
1
770
Mujeres en SEO Summit 2026 - Greatest Disaster Hits en Web Performance
guaca
0
170
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
570
ローカルLLMでどこまでコードが書けるか -拡張版 / How much code can be written on a local LLM Extended
kishida
10
4k
Inside Stream API
skrb
1
710
さぁV100、メモリをお食べ・・・
nilpe
0
140
Featured
See All Featured
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
1.4k
Git: the NoSQL Database
bkeepers
PRO
432
67k
Pawsitive SEO: Lessons from My Dog (and Many Mistakes) on Thriving as a Consultant in the Age of AI
davidcarrasco
0
160
Code Reviewing Like a Champion
maltzj
528
40k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
170
Producing Creativity
orderedlist
PRO
348
40k
Building Flexible Design Systems
yeseniaperezcruz
330
40k
Site-Speed That Sticks
csswizardry
13
1.2k
Embracing the Ebb and Flow
colly
88
5.1k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
200
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.9k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
940
Transcript
第二部 継承とポリモーフィズム 2025/03/26 社内勉強会 オブジェクト指向入門 1
2 • サンプルプログラムはJavaで書いています ◦ 言語によらない内容なのでJavaを知らなくても大丈夫 • 説明のために簡略化している場合があります 前置き
3 • オブジェクト指向ってなに? • 面倒だから/難しいから使いたくない という人に • オブジェクト指向の良さを知ってもらう • クラスを使って実装したくなってもらう
ことを目指す 想定読者とねらい
4 はじめに
5 1. クラス(カプセル化) 2. 継承 3. ポリモーフィズム オブジェクト指向の三大要素
1. クラス(カプセル化) 2. 継承 3. ポリモーフィズム 6 オブジェクト指向 の三大要素 関連するデータとロジックをまとめる
オブジェクト指向は バグを減らすための考え方
例えばこんなかんじ: Moneyクラス 7 金額を表すデータ 金額データを扱う ロジック
これだけ覚えて帰ってください 8 simple, small
9 1. クラス(カプセル化) 2. 継承 3. ポリモーフィズム オブジェクト指向の三大要素 今回はこちらについて話します
10 • 保守しやすいコードを書くために大事な概念 • 実務でもよく登場する設計パターン なぜこの話をするのか?
11 • 保守しやすいコードを書くために大事な概念 • 実務でもよく登場する設計パターン なぜこの話をするのか? • 理解しやすい • 変更しやすい
• テストしやすい
12 複雑な条件分岐 こんな経験ないですか?
13 複雑な条件分岐 なぜ条件分岐なんてものが存在するのか? こんな経験ないですか?
14 なぜ条件分岐なんてものが 存在するのか?
15 なぜ条件分岐なんてものが 存在するのか? 基本的に同じだけどちょっとだけ違う
あるある • 区分によって処理を変えたい • 条件に当てはまるデータだけ 処理したい 16 なぜ条件分岐なんてものが 存在するのか? 基本的に同じ
だけどちょっとだけ違う
17 基本的に同じだけど ちょっとだけ違う 今回のキーワード
18 継承 ポリモーフィズム 基本的に同じだけどちょっとだけ違うものをうまく扱う
19 継承 Inheritance
20 親クラスの機能を子クラスが引き継ぐ仕組み 継承とは? クラス 機能
21 親クラスの機能を子クラスが引き継ぐ仕組み 継承とは? 犬は「吠える」「走る」だけでなく 「食べる」「眠る」もできる (動物の機能を引き継ぐ) クラス 機能
22 継承の実装例
23 継承の実装例
24 • 共通処理の再利用 • コードの重複削減 継承のうれしさ
25 継承を使わない場合 コードの重複
26 継承を使う場合 共通処理は親クラスに 切り出して再利用 子クラスには差分を記述
27 共通化・重複削減だけを 目的に継承するのは危険 ただし
28 • 親クラスを変更すると子クラスの振る舞いも変わる ◦ 関連の薄い親子は思わぬバグが発生する ◦ 親クラスが子クラスのことを気にし始めるとよくない • 継承を繰り返すと階層が深くなっていく ◦
階層が深くなるほど保守性が下がる ◦ ソースコードを読みづらい、変更が大変 継承の乱用は危険
29 1. 「一種である(is-a)」関係 2. リスコフの置換原則(SOLID原則の”L”) 継承をうまく扱うガイドライン
30 継承を使う場合、これを満たすことを絶対に確認するべき • 犬は動物の一種である(dog is-a animal) 「一種である( is-a)」関係 動物 犬
ヒト
31 親クラスを子クラスに置き換えても問題なく動作しなければならない リスコフの置換原則 原文はけっこう難しいので意訳
32 親クラスを子クラスに置き換えても問題なく動作しなければならない リスコフの置換原則 原文はけっこう難しいので意訳 ハトは飛べるが、ペンギンは飛べない →リスコフの置換原則に違反🙅
33 基本的に同じ だけど ちょっとだけ違う 継承
34 ポリモーフィズム Polymorphism 多態性
35 同じメソッドで、オブジェクトごとに振る舞いが違うこと ポリモーフィズムとは? 同じ「食べる」でも ヒトの「食べる」と 犬の「食べる」は異なる
36 ポリモーフィズムの実装例 オーバーライド: 親クラスのメソッドを上書きする
37 ポリモーフィズムの実装例
38 ポリモーフィズムの実装例
子クラスは親クラスの機能を引き継ぐ =子クラスは親クラスとして扱える 39 ポリモーフィズムの真髄
40 ポリモーフィズムの真髄 犬クラスは動物クラスとして扱える
41 ポリモーフィズムの真髄 犬クラスは動物クラスとして扱える 同じ動物クラス なのに、 振る舞いが異なる !
42 1. if文やswitch文などの条件分岐を減らせる 2. コードの再利用性が高まる 3. 新しい機能追加が簡単 ポリモーフィズムのうれしさ
43 1. if文やswitch文などの条件分岐を減らせる 引数にヒトクラスを渡すのか、 犬クラスを渡すのかで処理が変わる ポリモーフィズムなし ポリモーフィズムあり
44 2. コードの再利用性が高まる 🙅ヒトクラスと犬クラスに対して 個別に実装する 🙆動物クラスに対して実装する →ヒトクラスと犬クラスで再利用できる ポリモーフィズムなし ポリモーフィズムあり
猫クラスを追加する場合 45 3. 新しい機能追加が簡単 動物クラスを使う側の実装や、 ヒトクラスと犬クラスの実装を変える必要がない
46 親クラスで定義されていないメソッドは使えない ポリモーフィズムの注意点 ヒトクラスと犬クラスをまとめて 動物クラスとして扱うための制約
基本的に同じ だけど ちょっとだけ違う 47 ポリモーフィズム
48 そうは言っても 実務でどう使うんですか?
49 ケース1:コントローラーの共通処理 ケース2:通知方法の切り替え 継承・ポリモーフィズムの簡単なユースケース
50 ケース1:コントローラーの共通処理 認証やログなどの共通処理を親クラスに切 り出し、子クラスで再利用する
51 ケース2:通知方法の切り替え メール通知とSlack通知をまとめて、条 件分岐せずに処理を切り替える
52 1. 継承について最近のトレンド 2. インターフェース 補足
53 継承は使い所が難しく、設計が複雑になる より柔軟な設計「コンポジション (委譲)」 • 「機能を持つ(has-a)」関係 • 継承よりも先にこちらを検討する 補足:1. 継承について最近のトレンド
54 • UserControllerは認証機能とログ機能を持つ コンポジション 「機能を持つ( has-a)」関係 継承
55 インターフェースで定義された機能を実装クラスに持たせる仕組み こちらも、継承より先に検討するべき方法 補足:2. インターフェース
56 補足:2. インターフェース インターフェースを実装する 使い方は継承とほぼ変わらない
57 1. 複数のインターフェースを実装できる 2. 「暗黙の実装」がない インターフェースの利点
58 1. 複数のインターフェースを実装できる ペンギンは飛べないので、 Flyableインターフェースを実装しなければよい
59 2. 「暗黙の実装」がない 親クラスの実装を上書きしない選 択も可能 →👿暗黙の実装 実装クラスでは実装が強制される →👼暗黙の実装なし 継承 インターフェース
• 基本的に同じだけどちょっとだけ違うものをうまく扱う • 継承:共通処理の再利用 • ポリモーフィズム:柔軟な振る舞いの切り替え • うまく使って保守しやすいコードを書こう! ◦ ただし、継承を使う場合はよく検討しましょう
◦ コンポジションとインターフェースで実現できるとベター 60 まとめ
61 • SOLID原則 • デザインパターン • ドメイン駆動設計 次に学ぶとよいもの(プログラミング関連)
62 • 具体と抽象 次に学ぶとよいもの(プログラミング以外) https://speakerdeck.com/soudai/a bstraction-and-concretization
63 参考文献