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 + iOS アーキテクチャの実践
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Nao
February 19, 2026
Programming
150
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Kotlin Multiplatform + iOS アーキテクチャの実践
Nao
February 19, 2026
Other Decks in Programming
See All in Programming
代数的データ型って何が嬉しいの? #frontend_phpcon_do
kajitack
8
3.7k
メソッドのジェネリクスでGoの夢は広がるか? / Kyoto.go #65
utgwkk
3
790
ふつうのFeature Flag実践入門
irof
7
4k
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
410
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
530
決定論的オーケストレーションの設計と実装 / Design and Implementation of Deterministic Orchestration
nrslib
4
1.4k
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
550
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
250
Signal Forms: Beyond the Basics @ngBaguette 2026 in Paris
manfredsteyer
PRO
0
250
「エンジニアインターン、どうやって取った?」準備のリアルを語るLT会 Progate BAR
akiomatic
0
130
Oxlintのカスタムルールの現況
syumai
6
1.1k
Featured
See All Featured
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
150
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.9k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.2k
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
590
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
840
Information Architects: The Missing Link in Design Systems
soysaucechin
0
970
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.2k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4.1k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
Darren the Foodie - Storyboard
khoart
PRO
3
3.4k
Done Done
chrislema
186
16k
Transcript
Kotlin Multiplatform + iOS アーキテクチャの実践 1
自己紹介 PROFILE 名前: 権 奈悟 所属: ディップ株式会社 担当: モバイル開発(iOS /
KMP ) ABOUT ハマっているもの: ドバイチョコ餅クッキー(두쫀쿠/ ドゥチ ョンク) 2
会社概要 3
ここから技術パート KMP の実運用での使い分けを共有します。 4
今日話すこと / 話さないこと 話すこと KMP 全体アーキテクチャ iOS アーキテクチャ KMP 連携(SKIE
/ XCFramework ) 話さないこと コードの細かい実装テクニック 画面ごとの仕様説明 KMP 導入手順の完全ガイド 5
導入 CONTEXT バイトル(15 年以上) → 長期運用でレガシー蓄積 → 大規模リアーキを実施 従来: Android
/ iOS 個別ネイティブ開発 → 方針: 工数削減とネイティブ体験の両立 → 採用: ビジネスロジックをKMP 共有、UI は各OS ネイティブ 6
KMP 全体アーキテクチャ Presentation は各OS ネイティブ実装(Android / iOS ) shared で
Domain / Data をKMP 共有 model はPure Domain Model (インフラ依存ゼロ) 7
データ変換フロー(Entity / Model / DTO ) Entity (DB ) ->
Mapper -> Model (Domain ) <- Mapper <- DTO (API ) Entity: Data 層の永続化モデル(Room ) DTO: Data 層の通信モデル(OpenAPI 生成) Model: Domain 層のビジネスモデル(Pure Kotlin ) model/ はインフラ依存ゼロ(CI で担保) 8
iOS のUI アーキテクチャ 画面ごとに状態管理がバラバラだと、状態遷移の追跡とKMP 連携の責務分離が難しくなる 自作MVI アーキテクチャ(Store Pattern )を採用 9
iOS Store Pattern 基本構造 Intent: ユーザー操作を表現す る enum Store: Intent
受信とReducer 実 行 State: 画面の単一状態 View: 描画とIntent 送信 基本フロー Intent Store State View 10
iOS Store Pattern 概要 iOS 側は自前MVI をStore Pattern で実装 Android
MVI と読み方を揃え、チーム認知を統一 @Observable (iOS 17+ )でState 変更を自動検知 外部ライブラリ依存を増やさずKMP 統合をシンプルに維持 11
iOS Store Pattern (Intent 駆動) @MainActor @Observable final class MyPageStore
{ var state: MyPageViewState func send(_ intent: MyPageIntent) { switch intent { case .logoutTapped: state.showLogoutConfirmation = true case .logoutConfirmed: logoutTask = Task { @MainActor in await performLogout() } case .dipIdAuthCompleted(let result): handleAuthResult(result) } } } 12
Store Pattern のメリット 複雑な機能にスケールしやすい 同じパターンのまま機能拡張できる 小規模から大規模まで設計を継続できる Intent/State の分割で見通しを維持しやすい チーム運用しやすい Android
(MVI )と似た設計で読み方を統一 UI イベントの扱い方を共通化できる レビュー観点を揃えやすい Intent の入口をsend(_:) に統一することで、 KMP UseCase 呼び出しの責務と非同期処理を整理しやすい 13
KMP 連携の全体像 XCFRAMEWORK + OBJECTIVE-C ヘッダ経由 + SKIE SwiftUI View
→ Store → iOS Bridge Shared.xcframework → Objective-C ヘッダ(.h ) → KMP UseCase 配布単位は Shared.xcframework Kotlin API はObjective-C ヘッダとして公開され、Swift から利用される SKIE でSwift 側の呼び出し体験を改善(suspend → async , Flow → AsyncSequence ) 14
XCFramework 運用と今後 現行 ./gradlew :shared:assembleSharedXCFramework Xcode へ取り込み 運用は安定、改善余地はビルド時間 今後(Swift Export
) Objective-C ヘッダ経由の負担を減らせる可 能性 よりSwift らしいAPI 公開に期待 現時点はExperimental のため段階評価 Swift Export は現時点ではExperimental 。段階導入を前提に評価。 15
ご清聴ありがとうございました 16