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
個人アプリ開発 (メンテナンス) 14年の歴史 / My personal app devel...
Search
Yuki Anzai
December 09, 2023
Technology
1
870
個人アプリ開発 (メンテナンス) 14年の歴史 / My personal app development history
Yuki Anzai
December 09, 2023
Tweet
Share
More Decks by Yuki Anzai
See All by Yuki Anzai
MediaPipe と ML Kit ってどう ちがうの? / What is the difference between MediaPipe and ML Kit?
yanzm
0
760
アプリをリリースできる状態に保ったまま 段階的にリファクタリングするための 戦略と戦術 / Strategies and tactics for incremental refactoring
yanzm
8
3.8k
Kotlinらしいコードを書こう - Convert Java File to Kotlin File のあとにやること / What to do after Convert Java File to Kotlin File
yanzm
1
4.8k
Material 3 やめました / Good-bye M3 design system
yanzm
4
7.8k
Compose Multiplatform で Bluesky のクライアント作ってみた / Bluesky client with Compose Multiplatform
yanzm
0
600
Compose Transition Animation
yanzm
3
710
Material3 with Jetpack Compose
yanzm
3
3.8k
Jetpack Compose 1.2 新機能 / new features of Jetpack Compose 1.2
yanzm
0
510
Now in Android アプリ解説 / Now in Android App
yanzm
2
1.8k
Other Decks in Technology
See All in Technology
バクラクのドキュメント解析技術と実データにおける課題 / layerx-ccc-winter-2024
shimacos
2
1.1k
Microsoft Azure全冠になってみた ~アレを使い倒した者が試験を制す!?~/Obtained all Microsoft Azure certifications Those who use "that" to the full will win the exam! ?
yuj1osm
2
110
あの日俺達が夢見たサーバレスアーキテクチャ/the-serverless-architecture-we-dreamed-of
tomoki10
0
430
.NET 9 のパフォーマンス改善
nenonaninu
0
770
20241220_S3 tablesの使い方を検証してみた
handy
3
360
終了の危機にあった15年続くWebサービスを全力で存続させる - phpcon2024
yositosi
0
280
第3回Snowflake女子会_LT登壇資料(合成データ)_Taro_CCCMK
tarotaro0129
0
180
プロダクト開発を加速させるためのQA文化の築き方 / How to build QA culture to accelerate product development
mii3king
1
260
20241214_WACATE2024冬_テスト設計技法をチョット俯瞰してみよう
kzsuzuki
3
440
権威ドキュメントで振り返る2024 #年忘れセキュリティ2024
hirotomotaguchi
2
730
AIのコンプラは何故しんどい?
shujisado
1
190
How to be an AWS Community Builder | 君もAWS Community Builderになろう!〜2024 冬 CB募集直前対策編?!〜
coosuke
PRO
2
2.8k
Featured
See All Featured
XXLCSS - How to scale CSS and keep your sanity
sugarenia
247
1.3M
Docker and Python
trallard
42
3.1k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
169
50k
The Cost Of JavaScript in 2023
addyosmani
45
7k
[RailsConf 2023] Rails as a piece of cake
palkan
53
5k
Unsuck your backbone
ammeep
669
57k
Building Your Own Lightsaber
phodgson
103
6.1k
Building Flexible Design Systems
yeseniaperezcruz
327
38k
Fontdeck: Realign not Redesign
paulrobertlloyd
82
5.3k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
127
18k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
95
17k
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
330
21k
Transcript
個人アプリ開発 (メンテナンス) 14年の歴史 DevFest Tokyo 2023 Yuki Anzai (@yanzm)
https://android-developers.googleblog.com/2023/11/ensuring-high-quality-apps-on-google-play.html https://support.google.com/googleplay/android-developer/answer/14151465
None
None
月額 100 円のサブスクリプション 100 円の買い切り機能
初回リリースしたのいつだっけ?
リリース履歴からわかるか?
リリース履歴からわかるか?
App Bundle エクスプローラからわかるか?
App Bundle エクスプローラからわかるか?
App Bundle エクスプローラからわかるか?
初回リリースしたのいつだっけ? 初回リリース日 : 2009年12月29日にはリリース済み 2009年12月29日付の使い方のブログ記事が発掘されたため 初回リリース日 : 2011年1月頭ぐらいだった記憶 NfcAdapter が
API Level 9 ( = Gingergread) からで、 最初の Gingergread (= 2.3) が出たのが 2010年の12月
14年も開発(メンテナンス)続けるのつらくない?
14年も開発(メンテナンス)続けている要因 1. ユーザー
14年も開発(メンテナンス)続けている要因 1. ユーザー
14年も開発(メンテナンス)続けている要因 1. ユーザー 2. 自分もユーザー
14年も開発(メンテナンス)続けている要因 1. ユーザー 2. 自分もユーザー 3. 最新の開発手法を試せる
14年の開発(メンテナンス)で やってよかったこと Top 6 つらかったこと Top 10
ざっくり年表 2008年04月 GitHubが正式にサービス開始 2008年10月 Android Market 配信開始 2009年02月 Android Market
有料アプリ配信開始(US) 2009年04月 Android Cupcake 1.5 2009年07月 日本国内初のAndroid搭載スマートフォン「HT-03A」発売 2009年09月 Android Donut 1.6 2009年10月 Android Eclair 2.0 2009年12月 個人アプリ①初回リリース
ざっくり年表 2010年01月 Google公式初のフラグシップ端末「 Nexus One」発売 2010年05月 Android Froyo 2.2 2010年12月
Android Gingerbread 2.3 2011年01月 個人アプリ②初回リリース 2011年02月 Android Honeycomb 3.0 (Fragment 導入) 2011年02月 Android Market が Web 上に公開される 2011年04月 Android Market In-app Billing(アプリ内課金)開始 2011年10月 Android ICS 4.0
ざっくり年表 2012年03月 Android Market から Google Play に移行 2012年07月 Android
Jelly Bean 4.1 2013年05月 Google I/Oで「Android Studio」が発表される 2013年10月 Android KitKat 4.4 2014年11月 Android Lollipop 5.0(最初の Material Design) 2014年11月 RxJava 1.0.0 2014年12月 Android Studio 1.0.0 2015年10月 Android Marshmallow 6.0(Runtime permission 導入)
ざっくり年表 2016年08月 Android Nougat 7.0 2016年10月 Pixel 発売 2017年05月 Google
I/Oで「Kotlin」の公式サポートが発表される 2017年08月 Android Oreo 8.0 2018年08月 Android Pie 9.0 2018年10月 Kotlin Coroutines 1.0.0 2019年05月 Google I/O で Jetpack Compose が発表される 2019年09月 Android Q 10
ざっくり年表 2020年09月 Android R 11 2021年07月 Jetpack Compose 1.0.0 2021年10月
Android S 12 2022年08月 Android Tiramisu 13 2023年10月 Android Upside Down Cake 14
14年の開発(メンテナ ンス)でやってよかっ たこと Top 6 Editable Location
第6位 Github でソースコードを管理するようにした 2011年1月初回リリースだから 2年間どうしていた??? 初回コミットですでに v5…
第5位 CI を導入した Bitrise (2017年〜) → Github Actions
第4位 Renovate を導入した • 個人アプリは数ヶ月単位でさわらな いので、ライブラリの更新がすぐた まる • Renovate を導入してだいぶ楽に
なった • 先に CI を導入しておくべし
第3位 Dagger (DI) を導入した • テストが書きやすくなった! • EventBus にさよならできた
第2位 テストを書いた • 安心するためにテストを書いている • 個人アプリのテスターはほぼ自分 • 自動テストで負荷を減らさないとつ らい!
第1位 README、コメントを書いた • コード以外の雑多なことも忘れるか ら README は書こう • 未来の自分は他人! •
簡潔なコードが一番、でも仕様が簡 潔とは限らない
14年の開発(メンテナ ンス)でつらかったこ と Top 10 Editable Location
第10位 build.gradle.kts への移行 • でてきたばかりの頃は書き方の情報 が少なすぎて大変だった • developer.android.com に移行 方法のドキュメントができてだいぶ
楽になった https://developer.android.com/build/migrate-to-kotlin-dsl
第9位 version catalog への移行 • 変換ツールがないからなにげに面倒 • Android Studio で
command + b ジャンプに対応するようになった のでもう移行してよい • developer.android.com に移行 方法のドキュメントがある https://developer.android.com/build/migrate-to-catalogs
第8位 非同期画像読み込みライブラリの移行 Imageloadlib → Picasso → Glide → Coil Imageloadlib
: 昔 Android 公式 ページに記載されていた画像読み込みのサ ンプル実装(だったはず)
第7位 Kotlin への移行 • Kotlin の勉強になった! • 段階的に移行できるのが素晴らしい • 全て移行するまでかなり時間がか
かった • やり切るには根気がいる
第6位 Android Studio への移行 • 昔は Eclipse という IDE で開発
していた • ビルドも Gradle ではなかった • 昔のプロジェクトを Android Studio で開くと、新しいプロジェ クト構成にした別プロジェクトを 作ってくれる機能があった(今もあ るはず)
第5位 EXTERNAL_STORAGE permission 廃止 • 独自のバックアップ機能があって (これは公式のバックアップ機能が ない時代からアプリをリリースして たので)、そのためにバックアップ データを外部ストレージに保存して
いた • 保存先を選択する機能、バージョンご との画面切り替え機能を実装しなくて はいけなくなった
第4位 UI の全面書き換え(複数回) 2系の UI → 4系の UI ActionBarSherlock →
5系の UI Material Design + AppCompat → Compose + M3 Compose への移行 • Compose 自体のコーディングは楽し い • 全画面やるから時間がかかる • Bottom Tab + Fragment の構成を Compose に移行する部分は段階的に できないので大変だった • View ベースで書いた UI テストが全 部さよならになったのはちょっとつら かった
2系の UI (2009年)
第3位 通信周りの書き換え AsyncTask → Loader → RxJava → Coroutines RxJava
• 2018年に導入して XX 年に Coroutines に移行した • RxJava 部分のコードを読み解くの が大変(忘れてるから) • 複雑なことをしていなかったので、 その点は助かった
第2位 Billing Library の更新 • 3 → 4 (だったと思う)の更新が大 変だった
◦ 全面的に API が変わってて検証も 必要だし、ぎりぎりまで後回しにし てた… • Billing 周りの検証はもう少しど うにかしたい
第1位 でかい Activity の解体 • 意味のわからない自分の書いたコー ドのリファクタリング • 「どんなにあれなコードでも書いた の自分なんだよなー」という経験は
貴重 • 最近はでかいクラスでつらくなるこ とは無くなったが、たくさんのクラ スが複雑に連携しててつらくなるこ とがある
まとめ • 個人アプリでも VCS、テスト、CI、 ライブラリ更新ツールは入れよう • 未来の自分は他人 • 簡潔でわかりやすいコードを書こう •
README やコメントを書こう • 放置しすぎるとメンテナンスが大変に なる ◦ せめて年1で更新しよう