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 under the hood
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
HyunWoo Lee
August 14, 2024
Programming
0
180
React Native under the hood
HYPER-APP 2024에서 진행한 React Native under the hood의 Speaker Deck입니다.
HyunWoo Lee
August 14, 2024
Tweet
Share
More Decks by HyunWoo Lee
See All by HyunWoo Lee
Navigating Dependency Injection with Metro
l2hyunwoo
1
280
How Android Uses Data Structures Behind The Scenes
l2hyunwoo
1
700
Understanding Kotlin Multiplatform (Busan)
l2hyunwoo
0
80
Understanding Kotlin Multiplatform
l2hyunwoo
0
330
파급효과: From AI to Android Development
l2hyunwoo
0
330
선언형 UI에서의 상태관리
l2hyunwoo
0
620
선언형 UI를 학습할 때 알아둬야하는 키워드들
l2hyunwoo
0
520
Essential concepts to know when learning Declarative UI
l2hyunwoo
2
1.6k
유연한 Composable 설계
l2hyunwoo
0
760
Other Decks in Programming
See All in Programming
野球解説AI Agentを開発してみた - 2026/02/27 LayerX社内LT会資料
shinyorke
PRO
0
350
PHPで TLSのプロトコルを実装してみる
higaki_program
0
370
脱 雰囲気実装!AgentCoreを良い感じにWEBアプリケーションに組み込むために
takuyay0ne
3
370
AI活用のコスパを最大化する方法
ochtum
0
270
CS教育のDX AIによる育成の効率化
niftycorp
PRO
0
150
RAGでハマりがちな"Excelの罠"を、データの構造化で突破する
harumiweb
9
3k
[PHPerKaigi 2026]PHPerKaigi2025の企画CodeGolfが最高すぎて社内で内製して半年運営して得た内製と運営の知見
ikezoemakoto
0
240
Codexに役割を持たせる 他のAIエージェントと組み合わせる実務Tips
o8n
4
1.4k
安いハードウェアでVulkan
fadis
0
720
AI時代の脳疲弊と向き合う ~言語学としてのPHP~
sakuraikotone
1
1.5k
[SF Ruby Feb'26] The Silicon Heel
palkan
0
120
コーディングルールの鮮度を保ちたい / keep-fresh-go-internal-conventions
handlename
0
230
Featured
See All Featured
The SEO identity crisis: Don't let AI make you average
varn
0
420
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
150
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.4k
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.2k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.2k
Rebuilding a faster, lazier Slack
samanthasiow
85
9.4k
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
84
A Tale of Four Properties
chriscoyier
163
24k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Writing Fast Ruby
sferik
630
63k
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
9.9k
Transcript
이현우, Viva Republica (Toss) React Native Under The Hood
HyunWoo Lee • Android(React Native) Developer, Toss • Organizer, Kotlin
User Groups • Organizer, GDG Songdo Github: https://github.com/l 2 hyunwoo LinkedIn: https://www.linkedin.com/in/hyunwoo-lee- 0412 / Medium: https://medium.com/@l 2 hyunwoo Velog: https://velog.io/@l 2 hyunwoo
From code to application 목차 Motivation React Native에 대한 간략한
소개
Motivation 이번 세션을 준비한 동기 누가 들으면 좋을까요?
Motivation
Motivation
Motivation 그래서 어떻게 돌아가죠?
Introduction to React Native Learn Once, Write Anywhere
React Native
React Native • 플랫폼별로 android/ios 폴더가 존재 • 플랫폼 빌드를
위한 여러가지 파일들이 포함되어 있음 • 이외의 Javascript 관련파일 구성 사항들은 React 프로젝트와 거의 동일
Fron code to application JavaScript에서 하나의 모바일 앱으로
// A.tsx <View> <Text>Hello A!</Text> </View> // B.tsx <View> <Text>Hello
B!</Text> </View>
JavaScript의 언어특성 • JavaScript는 모듈화된 자바스크립트 파일들을 읽어내지 못함 •
여러 파일들을 하나의 파일로 만들어주는 도구가 필요함 // A.tsx <View> <Text>Hello A!</Text> </View> // B.tsx <View> <Text>Hello B!</Text> </View>
Bundler 여러 모듈/파일을 하나의 파일로 묶는다
None
React Native - Metro • 번들링 • 유틸성 코드 주입(Polyfill)
• console.log를 네이티브에서 기록하기 위한 기능 • 리액트 네이티브 초기화(InitializeCore)
React Native - Metro • 번들링 • 유틸성 코드 주입(Polyfill)
• console.log를 네이티브에서 기록하기 위한 기능 • 리액트 네이티브 초기화(InitializeCore)
코드 변환 - Babel 메트로에 의해 번들링된 코드를 React Native
실행환경에 맞게 변환하는 과정 Babel이라는 라이브러리 활용 중
Runtime 코드가 실행되는 환경
None
None
None
First Choice - JSC(JavaScript Core) • Apple에서 제공하는 JavaScript Runtime
• JSC를 활용해서 리액트 네이티브를 돌아가게 만들 수 있었지만 • C 기반 API • 브릿지가 가져가야하는 너무 많은 책임들 • JSC와 리액트 네이티브의 강결합 • 이와 같은 문제점들이 대두됨
엔진을 추상화해볼까? - JSI
JSI의 Data Flow (Native to JS) • Android/iOS에서는 C++로 명령을
보내면서 JSI(shared memory layer 에서) 호출 • 메모리 업데이트 되면 JS에 반영이 되어서 표시됨
JSI의 Data Flow (JS to Native Module) 1 . 네이티브
모듈을 호출하면 JS엔진에 자바스크립트 값을 전달한다.
JSI의 Data Flow (JS to Native Module) 2 . HostFunction로
이 값이 전달되고. 함수는 이를 C++ dynamic으로 변환 한다.
JSI의 Data Flow (JS to Native Module) 3 . 이
값은 네이티브 모듈 인프라로 전달 된다. 4 . 플랫폼에서는 이를 플랫폼 타입으로 변환하고 메서드 호출하는 것을 확인
JSI를 활용한 Rendering 전략
And Next React Native is evolving right now.
New Architecture - Three Pillars • Turbo Module • Fabric
• Codegen
New Architecture - Three Pillars • Turbo Module • 특정
모듈을 지연 초기화시켜 앱 시작 속도 개선 • Fabric • 새로운 UI 렌더링 아키텍처. • 유저 인터랙션(스크롤, 제스처)을 메인스레드/네이티브 스레드에서 동기적으로 처리 • Codegen • 플랫폼 코드의 타입을 JS에서도 활용할 수 있게 정적 타이핑 지원 • TypeScript 활용시 이득
None
None