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
Kotlinのifを愛でる
Search
okuzawats
March 11, 2022
Programming
0
990
Kotlinのifを愛でる
「明日思わず誰かに伝えたくなる話 フラー x ちゅらデータ合同勉強会」(2022年3月11日)での発表資料です。
okuzawats
March 11, 2022
Tweet
Share
More Decks by okuzawats
See All by okuzawats
Androidアプリのモジュール分割における:x:commonを考える
okuzawats
1
430
「Chatwork」Android版アプリを 支える単体テストの現在
okuzawats
0
400
カンファレンス参加をいかに正当化するか
okuzawats
0
320
「勉強になった」で終わらせない、ストロングスタイルの勉強会
okuzawats
0
420
10年モノのAndroidアプリのコード品質を改善していく、3つの取り組み
okuzawats
0
1.3k
Androidアプリ開発におけるSonarCloudの活用
okuzawats
0
1.2k
何故、UseCaseは1メソッドなのか
okuzawats
3
2.2k
例外を投げるな、値を返せ
okuzawats
9
8.1k
GitHub ActionsでAndroidアプリのテストを回しまくってたら全プロジェクトのCI/CDが完全停止する寸前だった件
okuzawats
0
650
Other Decks in Programming
See All in Programming
IFSによる形状設計/デモシーンの魅力 @ 慶應大学SFC
gam0022
1
270
そのAIレビュー、レビューしてますか? / Are you reviewing those AI reviews?
rkaga
6
4.3k
ELYZA_Findy AI Engineering Summit登壇資料_AIコーディング時代に「ちゃんと」やること_toB LLMプロダクト開発舞台裏_20251216
elyza
2
1.3k
開発者から情シスまで - 多様なユーザー層に届けるAPI提供戦略 / Postman API Night Okinawa 2026 Winter
tasshi
0
160
ゆくKotlin くるRust
exoego
1
210
責任感のあるCloudWatchアラームを設計しよう
akihisaikeda
3
130
高速開発のためのコード整理術
sutetotanuki
1
330
SourceGeneratorのススメ
htkym
0
160
QAフローを最適化し、品質水準を満たしながらリリースまでの期間を最短化する #RSGT2026
shibayu36
2
4.1k
.NET Conf 2025 の興味のあるセッ ションを復習した / dotnet conf 2025 quick recap for backend engineer
tomohisa
0
120
MDN Web Docs に日本語翻訳でコントリビュート
ohmori_yusuke
0
610
AIで開発はどれくらい加速したのか?AIエージェントによるコード生成を、現場の評価と研究開発の評価の両面からdeep diveしてみる
daisuketakeda
1
920
Featured
See All Featured
Code Reviewing Like a Champion
maltzj
527
40k
The untapped power of vector embeddings
frankvandijk
1
1.5k
Ethics towards AI in product and experience design
skipperchong
2
180
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
110
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Product Roadmaps are Hard
iamctodd
PRO
55
12k
Practical Orchestrator
shlominoach
191
11k
Raft: Consensus for Rubyists
vanstee
141
7.3k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
22k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
0
130
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
240
Transcript
Kotlinのifを愛でる okuzawats 明日思わず誰かに伝えたくなる話 2022/03/11
自己紹介 奥澤(@okuzawats) Androidアプリエンジニ ア@フラー株式会社 テックリード 「Jetpack Composeに よるAndroid MVVMアー キテクチャ入門」の著者
今夜のトピックス 1. 自己紹介 2. なんでKotlinのifを愛でるのか 3. Coding Conventions 4. 事例
5. NG例 6. まとめ
なんでKotlinのifを愛でるのか ifは最も基本的なプログラムの構成要素 ifに思い入れを持ってプログラムを書くことで、他のところもいい感じに書けるようになる(かもしれない) 逆に言うと、ifすら蔑ろにすると他のところも残念なことになりそう(偏見) Coding conventionsを読む習慣を付ける
Coding Conventions Kotlin公式のCoding conventions https://kotlinlang.org/docs/coding-conventions.html AndroidのKotlin style guide https://developer.android.com/kotlin/style-guide
ifに関するCoding conventions AndroidのKotlin style guideには以下の記載がある
ifに関するCoding conventions つまり、 みたいに一行に収まる(三項演算子みたいな)if-elseか、 みたいにブロックを書くかのどちらか。
Kotlin公式のCoding conventionsには明確に書かれてないけどサンプルコードに示されるif-elseはこのスタイルで書かれている
ここまでが前置きで、これを踏まえて愛でていきます。
example.1 ひとつひとつreturnを書 く
example.1 ひとつひとつreturnを書 く 寸評 古き良き書き方実家のような安心感だが、IDEに怒られるのが玉に瑕。 Kotlinのifは値を返す式なので、ifを返せば良い。その方がKotlinらしいコードになる(と思う)。
example.2 ifをreturnする
example.2 ifをreturnする 寸評 直接if-elseの評価結果を返すので、どんな値がreturnされるのかがわかりやすい。 returnの前に早期リターンすることは可能なので、単にif-elseだけ見ていれば良いというわけではないのが玉に瑕。 example.1よりもKotlinらしいコードになった(と思う)。
example.3 ブロックを省略する
example.3 ブロックを省略する 寸評 Kotlin style guideに書かれている書き方(ただし一行に収まる場合)。三項演算子の代わりに使えてしまう。 Kotlinらしい書き方だけど、一行が長くなると改行が欲しくなり、ブロックを足さないといけなくなるのが玉に瑕。
example.4 関数本体を返す
example.4 関数本体を返す 寸評 早期リターンなどが発生し得ない書き方。 if-elseの評価結果が返されるので、どんな値が返されるのかは一目瞭然。 個人的には好き。 行数が少なくなって人類が幸せになる。
example.5 Scalaでみる書き方
example.5 Scalaでみる書き方 寸評 Scalaだとこういう書き方をする気がする(Scalaというか関数型言語?) 個人的にはこの書き方が一番好きだけど、チーム開発だと推しにくい。 example.3、example.4くらいがちょうどいいかもしれない。 書籍Functional Programming Kotlinではこの書き方をしているので、関数型に馴染みがあるとこういう書き方を好むのかもしれない。
NG例
NG1 ブロック省略&改行あり
NG1 ブロック省略&改行あり 寸評 Kotlin style guide違反。 何で違反になっているかはわからない Dangling else?
NG2 ifとelseが非対称
NG2 ifとelseが非対称 寸評 個人的にはNG。if-elseが非対称なので目が滑る。 if-elseを対象的に(同じ書き方で)書きたい。
発表時間の都合で以下略 処理の途中でifを使って副作用のあるコードを実行するパターン 早期リターンするパターン
まとめ Kotlinはifだけ見ても色々な書き方ができる。 Kotlinの言語機能を活かした、Kotlinらしいコードが書けると読みやすいコードになると思う。 自分たちだけの最強のifを見つけよう!