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
React Native 卒業後の「スタディサプリ」の進路
Search
Ryosuke Ito
April 10, 2023
Technology
2.4k
2
Share
React Native 卒業後の「スタディサプリ」の進路
2023-04-12 モバイルアプリの技術的負債 みんなで学ぶ Lunch LT の発表資料です。
https://findy.connpass.com/event/276159/
Ryosuke Ito
April 10, 2023
More Decks by Ryosuke Ito
See All by Ryosuke Ito
iOS app meets GraphQL
manicmaniac
0
4k
`shell invocation` in Python 2
manicmaniac
0
110
Debugging Apollo iOS with Apollo Client Developer Tools
manicmaniac
0
64
Other Decks in Technology
See All in Technology
15年メンテしてきたdotfilesから開発トレンドを振り返る 2011 - 2026
giginet
PRO
2
280
マルチモーダル非構造データとの闘い
shibuiwilliam
1
180
GitHub Copilotを極める会 - 開発者のための活用術
findy_eventslides
4
2.2k
Network Firewall Proxyで 自前プロキシを消し去ることができるのか
gusandayo
0
190
Oracle Cloud Infrastructure(OCI):Onboarding Session(はじめてのOCI/Oracle Supportご利⽤ガイド)
oracle4engineer
PRO
2
17k
制約を設計する - 非決定性との境界線 / Designing constraints
soudai
PRO
6
1.8k
Databricks Lakebaseを用いたAIエージェント連携
daiki_akimoto_nttd
0
150
GitHub Actions侵害 — 相次ぐ事例を振り返り、次なる脅威に備える
flatt_security
13
7.6k
主催・運営として"場をつくる”というアウトプットのススメ
_mossann_t
0
110
ブラックボックス化したMLシステムのVertex AI移行 / mlops_community_62
visional_engineering_and_design
1
280
ADOTで始めるサーバレスアーキテクチャのオブザーバビリティ
alchemy1115
2
150
サイボウズフロントエンドの活動から考える探究と発信
mugi_uno
0
110
Featured
See All Featured
Navigating Team Friction
lara
192
16k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
64
53k
Into the Great Unknown - MozCon
thekraken
40
2.3k
The Language of Interfaces
destraynor
162
26k
Odyssey Design
rkendrick25
PRO
2
560
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
240
Building Applications with DynamoDB
mza
96
7k
How to make the Groovebox
asonas
2
2.1k
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
160
Optimising Largest Contentful Paint
csswizardry
37
3.6k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
470
Utilizing Notion as your number one productivity tool
mfonobong
4
280
Transcript
React Native 卒業後の「スタディサプリ」の進路 React Native 卒業後の「スタディサプリ」の 進路 @manicmaniac モバイルアプリの技術的負債 みんなで学ぶ
Lunch LT
React Native 卒業後の「スタディサプリ」の進路 Agenda | 01 02 03 04 自己紹介
React Native 卒業 学んだこと 今後の計画
React Native 卒業後の「スタディサプリ」の進路 自己紹介 01
React Native 卒業後の「スタディサプリ」の進路 伊東 良輔 @manicmaniac ➔ 株式会社リクルート ➔ 「スタディサプリ」iOS
チーム ➔ 2019 年 iOS エンジニアとして Quipper 入社 ➔ 2021 年からエンジニアリングマネージャー
React Native 卒業後の「スタディサプリ」の進路 スタディサプリの紹介
React Native 卒業後の「スタディサプリ」の進路 スタディサプリ 大学受験講座 の紹介 ➔ 月額制のオンライン学習サービス ➔ 主に高校生がターゲット
➔ 2015-11-17 に最初のコミット ➔ Swift コードは約15万行 ➔ 2018 - 2021 React Native を一部画面で採用していた
React Native 卒業後の「スタディサプリ」の進路 React Native 卒業 02
React Native 卒業後の「スタディサプリ」の進路 React Native 卒業 https://blog.studysapuri.jp/entry/2021/07/21/080000
React Native 卒業後の「スタディサプリ」の進路 React Native 導入の経緯 ➔ モバイルエンジニア不足 ◆ Web
エンジニアが開発に参加できた ➔ 開発の高速化の要請 ◆ Hot reload を利用した高速な UI 開発 ◆ Web フロントエンドのコード再利用
React Native 卒業後の「スタディサプリ」の進路 2年後
React Native 卒業後の「スタディサプリ」の進路 React Native 卒業のきっかけ ➔ モバイルエンジニア不足の解消 ◆ Swift
エンジニアが十分採用できた ➔ 開発の高速化 ◆ ユーザー数が増えてスピードより品質を重視するようになった ◆ Web フロントエンドのコード再利用 • 長期間メンテされない状態が続いていた
React Native 卒業後の「スタディサプリ」の進路 React Native 卒業の方法 ➔ 事業は止めない ➔ 事業側にリスクを説明、理解を得てロードマップに載せた
➔ 複数のメンバーでタスクを並列化した ➔ リリースを分割してビッグバンリリースを避けた
React Native 卒業後の「スタディサプリ」の進路 学んだこと 03
React Native 卒業後の「スタディサプリ」の進路 React Native やってよかった ➔ 導入は正解だった ◆ 当時の大きな課題を解決した
• モバイルエンジニア不足 • 開発高速化の要請 ◆ React Native がなければ成長期を乗り越えられなかったかも
React Native 卒業後の「スタディサプリ」の進路 技術的負債との向き合い方 ➔ 技術的負債はなくせない ◆ ある時点での最適な選択が N 年後の未来でも最適とは限らない
➔ 計画的に返済する ◆ 技術的負債の返済計画を立て、関係者に説明する責任がある
React Native 卒業後の「スタディサプリ」の進路 今後の計画 04
React Native 卒業後の「スタディサプリ」の進路 新たな借入れ ➔ GraphQL (Apollo) ➔ SwiftUI ➔
Combine ➔ Swift Concurrency ➔ Swift Package
React Native 卒業後の「スタディサプリ」の進路 借入れ方針 ➔ 標準技術に寄せていく ◆ アプリの寿命は多くのライブラリより長くなる可能性が高い ◆ エンジニア採用がしやすい
➔ チームで ownership を持つ ◆ 勉強会など知見を蓄積する機会を作る
React Native 卒業後の「スタディサプリ」の進路 iOS / Android エンジニア募集! https://brand.studysapuri.jp/career/ 🔍「スタサプ 求人」
React Native 卒業後の「スタディサプリ」の進路 ご清聴ありがとうございました