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 Multiplatform
Search
Yuta Tomiyama
October 16, 2022
Programming
0
290
今だからこそ知りたいKotlin Multiplatform
2022/10/15 Zli 大LTにて発表
Yuta Tomiyama
October 16, 2022
Tweet
Share
More Decks by Yuta Tomiyama
See All by Yuta Tomiyama
モバイルアプリ開発を始めよう!
yt8492
0
46
Git勉強会
yt8492
0
100
なんでもやってみる勇気
yt8492
0
79
Android Autoが思ったよりしんどい話
yt8492
0
190
apollo-kotlinにcontributeした話
yt8492
0
120
DMM TVのSDカードダウンロード機能を実装した話
yt8492
1
830
State management and API calls in Jetpack Compose: Learning Apollo + Jetpack Compose through React Hooks
yt8492
0
1.2k
サーバーフレームワークの仕組みが気になったので車輪の再発明をしてみた
yt8492
0
190
Compose for Webを始めよう
yt8492
0
390
Other Decks in Programming
See All in Programming
iOSアプリ開発で 関数型プログラミングを実現する The Composable Architectureの紹介
yimajo
2
210
Effect の双対、Coeffect
yukikurage
5
1.4k
Create a website using Spatial Web
akkeylab
0
290
Passkeys for Java Developers
ynojima
3
860
アンドパッドの Go 勉強会「 gopher 会」とその内容の紹介
andpad
0
210
Claude Codeの使い方
ttnyt8701
1
110
XSLTで作るBrainfuck処理系
makki_d
0
200
人には人それぞれのサービス層がある
shimabox
3
680
インターフェース設計のコツとツボ
togishima
2
720
生成AIで日々のエラー調査を進めたい
yuyaabo
0
580
Datadog RUM 本番導入までの道
shinter61
1
280
List Unfolding - 'unfold' as the Computational Dual of 'fold', and how 'unfold' relates to 'iterate'"
philipschwarz
PRO
0
190
Featured
See All Featured
Designing Experiences People Love
moore
142
24k
A designer walks into a library…
pauljervisheath
206
24k
Six Lessons from altMBA
skipperchong
28
3.8k
How STYLIGHT went responsive
nonsquared
100
5.6k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
657
60k
Measuring & Analyzing Core Web Vitals
bluesmoon
7
480
Speed Design
sergeychernyshev
31
990
Product Roadmaps are Hard
iamctodd
PRO
53
11k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
3k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
6
690
Why You Should Never Use an ORM
jnunemaker
PRO
56
9.4k
VelocityConf: Rendering Performance Case Studies
addyosmani
329
24k
Transcript
今だからこそ知りたい Kotlin Multiplatform 2022/10/15 大LT
自己紹介 HN: マヤミト 本名: 富山雄太 GitHub: https://github.com/yt8492 趣味: Kotlin, Twitter,
同人音声 Twitter: yt8492
自己紹介 HN: マヤミト 本名: 富山雄太 GitHub: https://github.com/yt8492 趣味: Kotlin, Twitter,
同人音声 Twitter: yt8492 会津大学生なんですけど! Zli?のメンバーなんですけど!
自己紹介 HN: マヤミト 本名: 富山雄太 GitHub: https://github.com/yt8492 趣味: Kotlin, Twitter,
同人音声 Twitter: yt8492 嘘 を 付 き ま し た 会津大学生なんですけど! Zli?のメンバーなんですけど!
自己紹介 HN: マヤミト 本名: 富山雄太 GitHub: https://github.com/yt8492 趣味: Kotlin, Twitter,
同人音声 s1260119 Zli 元代表(2020年度) 合同会社DMM.com 動画配信事業部 Androidエンジニア Twitter: yt8492
動画配信事業部でAndroidアプリを 作ってるよ!🥰
動画配信事業部でAndroidアプリを 作ってるよ!🥰 おっと、その前に
⚠注意事項⚠
⚠注意事項⚠ 成人向け事業は2018年3月1日をもってDMM.comから分割し、株式会社デジタルコ マースへ継承しています。 また、同年8月1日よりデジタルコマース社運営の元、アダルト事業「DMM.R18」の名称 も変更し、「FANZA(ファンザ)」ブランドが誕生しました。 「FANZA(デジタルコマース社)」は「DMM.com」から完全に独立しており、事業会社とし てもブランドとしても、別々のものとなっています。 DMM.comは、デジタルコマース社からの業務委託として、FANZAの配信及びシステム 等の請負を行っています。
⚠注意事項⚠ 成人向け事業は2018年3月1日をもってDMM.comから分割し、株式会社デジタルコ マースへ継承しています。 また、同年8月1日よりデジタルコマース社運営の元、アダルト事業「DMM.R18」の名称 も変更し、「FANZA(ファンザ)」ブランドが誕生しました。 「FANZA(デジタルコマース社)」は「DMM.com」から完全に独立しており、事業会社とし てもブランドとしても、別々のものとなっています。 DMM.comは、デジタルコマース社からの業務委託として、FANZAの配信及びシステム 等の請負を行っています。
さて本題
そもそもKotlinとは? • 静的型付けなオブジェクト指向言語 • Androidアプリ開発やバックエンド開発で使われている ◦ もちろん弊社のAndroidアプリ開発でも使ってるよ! • JVM言語 ◦
Javaとの相互運用が可能
なぜKotlinはJavaと相互運用が可能なのか? • KotlinのコードがコンパイルされるとJavaのバイトコードになる ◦ IntelliJ IDEA / Android Studio の機能でJavaにデコンパイルすることも可能
• 最終的なランタイムはJVM ◦ 実行ファイルもJARなどの実行可能な形式にしてしまえば Kotlinの環境がなくてもJavaのランタイム さえあれば動かせる
Kotlinの特殊なランタイムがない →Javaのバイトコード以外も吐き出せるようにすれ ば任意のプラットフォームで動くものが作れるので は?(てんさいはかせ)
正解
Kotlin Multiplatformとは? • Kotlinのコードを様々な形式にコンパイルする • 複数のプラットフォームの処理を共通化できる common Android iOS
Kotlin Multiplatformとは? • 現状対応しているものは以下の通り ◦ JVM ◦ JavaScript ◦ macOS
◦ iOS ◦ tvOS ◦ watchOS ◦ Linux ◦ Windows ◦ Android NDK ◦ WebAssembly
Q. 実用性あんの?
A. あります! 弊社でも使ってます!
レイヤードアーキテクチャ 動画配信事業部での活用例 Domain UseCase UI Infra
レイヤードアーキテクチャ Domain層、Infra層、UseCase層をKotlinで共通化 動画配信事業部での活用例 Domain UseCase UI Infra
レイヤードアーキテクチャ Domain層、Infra層、UseCase層をKotlinで共通化 共通化した処理をそれぞれのネイティブから呼び出す 動画配信事業部での活用例 native-shared Android Jetpack Compose iOS SwiftUI
使用しているKotlin Multiplatform対応ライブラリ • ロギング ◦ Napier • HTTPクライアント ◦ Ktor
Client • GraphQLクライアント ◦ Apollo Kotlin • SQL ◦ SQLDelight • DI ◦ Koin • などなど
結局どのくらい実用性があるのか? • AndroidとiOSでビジネスロジックを共通化するといった使い方であればほぼ問題 なし ◦ 先日、Kotlin Multiplatform Mobileがついにbetaになった ▪ 「ほぼ完成してプロジェクトに安全に使用できる」と公式がアナウンスしている
◦ ここ数年でいろんな会社がプロダクション導入している ◦ サードパーティ製ライブラリも年々増えている ◦ 非同期処理周りやメモリ管理周りがまだ変更が入ったりするので注意が必要 • 共通化を考えないのであれば現状でもいろいろできる ◦ Kotlin/JSでWebフロントとか ◦ Kotlin/NativeでCLIツールを実装するとか
Q. UIの共通化まではできないの?
A. できます(震え声)
Compose Multiplatformなんてものがあったりする
Compose Multiplatformとは • AndroidのJetpack ComposeをもとにJetBrainsが開発している • DesktopアプリとWebアプリがKotlinとComposeで書ける ◦ DesktopはJVMとSkia、WebはDOMベースで動く ◦
WebはDOMベースなのでAndroidやDesktopで使えるComposable関数が使えなかったりする • Web、iOS、macOSでもskiaベースのComposeが動くように(experimental) ◦ Android, iOS, Desktop, Webで理論上同じUIが動く
Compose Multiplatformとは • AndroidのJetpack ComposeをもとにJetBrainsが開発している • DesktopアプリとWebアプリがKotlinとComposeで書ける ◦ DesktopはJVMとSkia、WebはDOMベースで動く ◦
WebはDOMベースなのでAndroidやDesktopで使えるComposable関数が使えなかったりする • Web、iOS、macOSでもskiaベースのComposeが動くように(experimental) ◦ Android, iOS, Desktop, Webで理論上同じUIが動く
Compose Multiplatformは使い物になるのか? • 今はまだちょっと厳しい ◦ DesktopやWeb(DOM)は意外と使い物になる ◦ SkiaベースのComposeだと、UIのコンポーネント自体はそこそこ充実しているが、 iOSの挙動など にバグが多く残っている
◦ Compose Multiplatformの完成度がFlutterレベルになればワンチャンあると思う • そもそもDesktopとWeb(DOM)以外はbetaリリースすらされていないので、それ なりに不安定
これからのKotlin Multiplatform • 周辺ライブラリのさらなる充実 ◦ 先日、Androidの公式ライブラリ群の一部が Multiplatformに対応した ▪ androidx.datastore ▪
androidx.collection ◦ Kotlin Multiplatform Mobileがbetaになったことで、今後更に充実していくと予想 • Compose Multiplatformの進化に期待 ◦ Compose for iOSは現状バグだらけだが、バグが少なくなり、 Flutterレベルまで共通化できるもの が増えれば、可能性は十分にある
まとめ • Kotlin Multiplatformはいろんなプラットフォームの処理をKotlinで実装できる • UI以外のビジネスロジックなどの処理の共通化であれば現状でもプロダクション導 入に耐えうるレベル • UIの共通化はCompose Multiplatformの進化に期待
• 弊社に来ればKotlin Multiplatformで仕事ができるよ!(宣伝)