4.2 KiB
4.2 KiB
category, tags, title, description, last_updated
| category | tags | title | description | last_updated | |||
|---|---|---|---|---|---|---|---|
| Architecture |
|
Bridgeless New Architecture | Bridgeless New Architecture(브릿지리스 신규 아키텍처)는 React Native의 역사상 가장 중요한 변화로, 기존의 비동기 자바스크립트 브릿지에서 발생하던 성능 병목 현상을 해결하기 위해 도입된 혁신적인 구조이다 [1, 2]. | 2026-05-04 |
Bridgeless New Architecture
📌 Brief Summary
Bridgeless New Architecture(브릿지리스 신규 아키텍처)는 React Native의 역사상 가장 중요한 변화로, 기존의 비동기 자바스크립트 브릿지에서 발생하던 성능 병목 현상을 해결하기 위해 도입된 혁신적인 구조이다 [1, 2]. 이 아키텍처는 JSI(JavaScript Interface)를 통해 자바스크립트와 네이티브 계층 간의 직접적이고 동기적인 통신을 지원한다 [3, 4]. 결과적으로 데이터 직렬화 오버헤드와 지연 시간(Latency)을 줄이고 UI 반응성을 극대화하여, React Native 앱의 성능을 순수 네이티브 수준에 가깝게 끌어올리는 핵심 역할을 한다 [3-5].
📖 Core Content
- 비동기 브릿지의 제거 (Elimination of the Bridge): 과거 React Native의 가장 큰 성능 한계는 자바스크립트의 호출을 네이티브 명령으로 변환할 때 JSON 문자열로 직렬화(serialization)하여 통신하는 비동기 브릿지였다 [1, 6]. 신규 아키텍처(React Native 0.74부터 기본 활성화)는 이 브릿지를 완전히 제거하고, 오버헤드가 없는 보다 직접적이고 효율적인 통신 시스템으로 대체하였다 [1, 4, 6].
- JSI (JavaScript Interface): 신규 아키텍처의 근간이 되는 JSI는 C++ 기반의 경량 레이어로, 자바스크립트 코드가 네이티브 객체를 직접적이고 동기적으로 참조 및 호출할 수 있게 해준다 [3, 6]. 직렬화 과정을 생략하게 해 주어 스레드 간 실시간에 가까운 고성능 통신을 가능하게 한다 [3, 6].
- 패브릭 렌더러 (Fabric Renderer): 새로운 UI 렌더링 시스템인 패브릭은 C++ 환경에서 섀도 트리(Shadow Tree)를 생성해 스레드 간 공유를 가능하게 한다 [7]. 비동기적인 왕복 과정 없이 네이티브 뷰를 측정하고 렌더링할 수 있어, 동시 렌더링(Concurrent Rendering)과 동기적 레이아웃 계산을 지원하며 UI의 반응성을 대폭 향상시킨다 [6, 7].
- 터보모듈 (TurboModules): 기존에는 앱 시작 시 모든 네이티브 모듈을 초기화해야 했으나, 터보모듈은 차세대 네이티브 모듈 시스템으로서 모듈이 필요할 때만 로드되는 지연 로딩(Lazy loading) 방식을 취한다 [6, 8]. 동기식 네이티브 호출을 지원할 뿐만 아니라, 앱의 초기 시작 시간과 메모리 사용량을 효과적으로 줄여준다 [6, 8].
- 코드젠 (Codegen): 동적 타입의 자바스크립트 환경과 정적 타입의 네이티브 환경(Java/Kotlin, Objective-C/Swift) 간의 안전한 통신을 보장하기 위해 도입되었다 [9]. 빌드 시점에 타입 정의를 분석하여 필요한 C++ 보일러플레이트 코드를 자동 생성하므로, 런타임이 아닌 컴파일 타임에 오류를 잡아내고 전반적인 개발자 경험(DX)을 개선한다 [9].
⚖️ Trade-offs & Caveats
- 생태계 적응을 위한 과도기: React Native의 신규 아키텍처는 프레임워크의 기반을 뒤흔드는 거대한 변화이므로, 서드파티 라이브러리 및 패키지들이 새로운 구조(TurboModules, Fabric 등)에 완벽하게 호환되고 채택을 완료할 때까지 일정 시간이 필요하다 [6].
- 도입 및 마이그레이션 비용: 신규 아키텍처가 전면적인 기본값으로 완전히 정착되기 전까지의 이전 버전(예: 0.73) 환경에서는 이를 옵트인(Opt-in) 방식으로 활성화해야 한다 [2]. 앱에 통합된 기존 커스텀 네이티브 모듈이나 특정 라이브러리들이 JSI 기반의 동기적 호출 구조를 지원하지 않을 경우, 이에 대한 마이그레이션이나 검증 작업이 추가로 요구될 수 있다 [2, 6].
Last updated: 2026-05-03