Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up for free
アーキテクチャを明文化して開発に臨んだ話
akkie76
June 22, 2022
Technology
0
540
アーキテクチャを明文化して開発に臨んだ話
akkie76
June 22, 2022
Tweet
Share
More Decks by akkie76
See All by akkie76
Crashlytics と Android の連携で トラブルシューティングを効率化する
akkie76
0
150
アプリアーキテクチャを明文化しチームの開発効率をアップ
akkie76
1
430
こんなコードレビューは嫌だ
akkie76
0
430
アプリアーキテクチャを明文化しチームの開発効率をアップ
akkie76
1
890
チームの設計力を高めるためのTIPS
akkie76
0
510
明日からできるコードレビューの心構え
akkie76
0
310
これで失敗しない! JUnit 5 へのマイグレーション方法
akkie76
0
220
オブジェクト指向で類型化するコードレビュー
akkie76
0
230
レビューガイドラインで技術力を見える化する
akkie76
0
710
Other Decks in Technology
See All in Technology
データ分析基盤の要件分析の話(202201_JEDAI)
yabooun
0
400
cdk deployに必要な権限ってなんだ?
kinyok
0
190
OpenShift.Run2023_create-aro-with-terraform
ishiitaiki20fixer
1
360
CUEとKubernetesカスタムオペレータを用いた新しいネットワークコントローラをつくってみた
hrk091
1
300
もし本番ネットワークをまるごと仮想環境に”コピー”できたらうれしいですか? / janog51
corestate55
0
390
SPA・SSGでSSRのようなOGP対応!
simo123
2
160
OpenShiftのリリースノートを整理してみた
loftkun
2
450
組織に対してSREを適用するとどうなるか
kuniim
9
3.1k
Kaggleシミュレーションコンペの動向
nagiss
0
280
スクラム導入して変わったチーム、組織のありかた
yumechi
0
270
はじめてスポンサー運営PMをやってみてわかった4つのこと
andpad
2
100
NGINXENG JP#2 - 1-NGINX-エンジニアリング勉強会-きょうの見どころ
hiropo20
0
120
Featured
See All Featured
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
182
15k
Web development in the modern age
philhawksworth
197
9.6k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
224
50k
The Web Native Designer (August 2011)
paulrobertlloyd
76
2.2k
Designing on Purpose - Digital PM Summit 2013
jponch
108
5.9k
WebSockets: Embracing the real-time Web
robhawkes
58
6k
Git: the NoSQL Database
bkeepers
PRO
419
60k
How to Ace a Technical Interview
jacobian
270
21k
Why You Should Never Use an ORM
jnunemaker
PRO
49
7.9k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
32
6.7k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
13
1.1k
Raft: Consensus for Rubyists
vanstee
130
5.7k
Transcript
〜 Architecture を事前準備して臨んだ開発を振り返る 〜 Android Architecture を明文化して 新規開発に臨んだ話 Akihiko Sato
#78 iOS / Android 開発 Tips 共有会
自己紹介 佐藤 晶彦 株式会社ラクス 楽楽精算開発 モバイル開発 / Lead Engineer SaaS
(Backend, Frontend) / Mobile (iOS, Android) 主な業務は、設計 〜 受入、チームの課題改善など 最近のマイブームは、縄跳びトレーニング
今日伝えたいこと 開発開始前に Architecture を明文化して 良かったこと & 課題となったこと
背景 弊社では、 Native (Kotlin) 版と Cordova 版の 2 つの Android
アプリをリリースしています。 昨年 Native 版では Android 12 対応などを進めて来ましたが、 Cordova 版では FW のリリースと開発期間が合わないこともあり、 タイムリーな対応ができない状況でした。
背景 2 また、今後 Cordova 自体の開発が終了して EOL となった場合、 セキュリティリスクが生じる可能性も。。。
背景 3 他にも、市場に Cordova 開発者が少なくなっており、 採用面においてもなかなか厳しい状況でした・・・。 心機一転 Native 版に作り替えることになりました!
Android チームの現状 しかしながら、 Android チームは若手が中心で、 開発の苦戦は目に見えていたため、 事前に基本的方針として Architecture を定めることしました。
Architecture 選定にあたって 基本型として MVVM Architecture を採用することにしました。 まず Architecture を選定するにあたり ・
Android の公式 Architecture である ・モダンな Architecture を扱える技術力あるチームではない
Architecture 選定にあたって MVVM Architecture は 2017~8 年位から RxJava を主軸に 台頭した
Architecture ですが、 Jetpack Compose の進化と今後の展望を考えると、 Android の標準 Architecure として MVVM Architecture は 今後も Architecture として運用しやすいと考えました。
Architecture 選定にあたって 加えて Architecture 検討する上で関心の分離を重要な原則とし、 クラスの責務をできるだけシンプルに保つことで、 ライフサイクルに関連する多くの問題を回避し、 クラスごとのテストの容易性を向上させることにしました。
3 層レイヤー構造による構成 基本的なレイヤー構造として、 ・プレゼンテーションレイヤー ・ドメインレイヤー ・データレイヤー 3 層 MVVM Architecture
構成を採用
プレゼンテーション層( Presentation Layer ) プレゼンテーション層からユーザーに情報を表示し、入力を受け付ける機能を 持っています。具体的には、または外部入力によってデータが変更されるたび に、変更された情報を反映するよう UI を更新する必要があります。 主にプレゼンテーション層は、
Activity, Fragment, ViewModel や BindingModel に変換するための Converter を配置します。また、 RecyclerView を用いる場合、 Adapter や ViewHolder などもプレゼンテーション層に配置しま す。
ドメイン層( Domain Layer ) 複雑なビジネスロジックや複数の ViewModel で再利用される単純なビジネスロ ジックが隠蔽(カプセル化)されたレイヤーです。 ビジネスロジックの複雑さに対処する場合や再利用性を優先する場合、対象の ロジックをこのレイヤーに実装します。
また、各ユースケースでは異なるビジネスロジックが集約されるため、それぞれ のユースケースクラスは疎であることがアーキテクチャとして重要です。
データ層( Data Layer ) データ層は、アプリで扱うデータに関連するロジックが集約されます。 具体的には、アプリで使用するデータの作成、保存、変更方法( API に関するも のを含む)を決定する実際のロジックで構成されることがこのレイヤーの期待で す。
データ層は、それぞれが 0 から複数のデータソースを含むことができるリポジトリ で構成されます。また、アプリで処理するデータの種類ごとに Repository を作成 する必要があります。
Package 構成を明示
基本クラスのルールも明文化 ・ Activity ・ Fragment ・ ViewModel ・ UseCase ・
Repository ・ DI Module ・責務 ・命名規則 ・ルール(制約) ・実装例 ・テストで確認すること ・テスト実装例 明文化 ルールを明文化して、サンプルプロジェクトも用意
開発を進めて感じたこと ・チームの基本的技術力が向上 ・開発中に基本的なアーキテクチャの議論することがない 👉 開発に集中できる 👉 チームの生産性が高まった ・責務によりクラスを小さく分けたためテストが書きやすかった 👉 テスト品質の担保
課題に感じたこと ・ Package 構造 👉 技術駆動パッケージングよる参照関係 👉 レイヤー横断的な component をどう扱うか
・各レイヤーごとのによる依存性 👉 依存関係逆転原則を活用できていない 今後改善予定
まとめ Architecture を明文化すると 👉 チームの基本技術の向上 👉 チームの生産性の向上 👉 品質の向上 といった恩恵を受けることができるので、
皆様のチームでもトライしてみてはいかがでしょうか。
オンラインイベントや中途採用を積極的に行ってます! 最後に
ご清聴ありがとうございました