--- id: wiki-2026-0508-bridgeless-new-architecture title: Bridgeless New Architecture category: 10_Wiki/Topics status: verified canonical_id: self aliases: [React Native New Architecture, Fabric+TurboModules] duplicate_of: none source_trust_level: A confidence_score: 0.9 verification_status: applied tags: [react-native, architecture, jsi, fabric, turbomodules] raw_sources: [] last_reinforced: 2026-05-10 github_commit: pending tech_stack: language: javascript framework: react-native --- # Bridgeless New Architecture ## 매 한 줄 > **"매 async-bridge serialization 의 제거 — JS 와 native 의 direct memory call"**. 매 React Native 0.68 (Fabric, TurboModules) 부터 시작 → 0.74 default 로 출하된 architectural rewrite. 매 JSI (JavaScript Interface) 기반 synchronous interop 으로 60Hz/120Hz UI 동기화. ## 매 핵심 ### 매 Old Bridge 의 한계 - 매 모든 native↔JS 호출 의 JSON serialize → batched async queue. - 매 startup 에 module table 전체 의 eager registration. - 매 60fps 의 16.67ms budget 에 round-trip ≥ 2 frames 의 발생. - 매 frame-locked animation/gesture 의 jank. ### 매 New Architecture 의 3 pillars 1. **JSI**: C++ host object 의 JS-runtime direct binding. Hermes/JSC interchangeable. 2. **TurboModules**: native module 의 lazy load + sync invocation. 3. **Fabric**: shadow tree 의 C++ rewrite — concurrent rendering + thread-safe layout. ### 매 Codegen 의 역할 - 매 TS/Flow spec → C++/Java/ObjC scaffolding 의 자동 생성. - 매 type safety + boilerplate 의 elimination. ## 💻 패턴 ### TurboModule spec (TS) ```typescript // NativeCalculator.ts import type { TurboModule } from 'react-native'; import { TurboModuleRegistry } from 'react-native'; export interface Spec extends TurboModule { add(a: number, b: number): number; // sync! fetchUserAsync(id: string): Promise<{name: string}>; } export default TurboModuleRegistry.getEnforcing('Calculator'); ``` ### Fabric component spec ```typescript // MyViewNativeComponent.ts import { codegenNativeComponent, ViewProps } from 'react-native'; import type { Int32 } from 'react-native/Libraries/Types/CodegenTypes'; interface NativeProps extends ViewProps { intensity: Int32; color?: string; } export default codegenNativeComponent('MyView'); ``` ### JSI host function (C++) ```cpp // 매 native side 에서 JS function 의 expose auto add = jsi::Function::createFromHostFunction( rt, jsi::PropNameID::forAscii(rt, "add"), 2, [](jsi::Runtime& rt, const jsi::Value&, const jsi::Value* args, size_t) { return jsi::Value(args[0].asNumber() + args[1].asNumber()); }); rt.global().setProperty(rt, "add", std::move(add)); ``` ### Bridgeless mode 활성화 ```javascript // react-native.config.js module.exports = { project: { ios: {}, android: {}, }, // 매 RN 0.74+ 부터 default true reactNativeArchitectures: 'arm64-v8a,x86_64', }; ``` ```ruby # ios/Podfile use_react_native!( :path => config[:reactNativePath], :fabric_enabled => true, :new_arch_enabled => true, ) ``` ### 매 sync layout measurement ```typescript import { findNodeHandle, UIManager } from 'react-native'; // 매 Fabric 에서 sync measure 의 가능 const handle = findNodeHandle(ref.current); UIManager.measureInWindow(handle, (x, y, w, h) => { // 매 동일 frame 안에 layout 완료 의 보장 }); ``` ### Reanimated 3 worklet (JSI 활용) ```typescript import Animated, { useSharedValue, useAnimatedStyle, withSpring } from 'react-native-reanimated'; const offset = useSharedValue(0); const style = useAnimatedStyle(() => ({ transform: [{ translateX: withSpring(offset.value) }], })); // 매 UI thread 에서 worklet 의 directly run — bridge 없음 ``` ## 매 결정 기준 | 상황 | Approach | |---|---| | 매 신규 RN app (2026) | Bridgeless default — 매 그대로 사용 | | 매 legacy native module 다수 | Interop layer 의 활용 (자동 shim) | | 매 60Hz+ animation 필요 | Reanimated 3 + Fabric 의 mandatory | | 매 startup 시간 critical | TurboModule lazy init 의 활용 | **기본값**: 매 RN 0.76+ 의 Bridgeless on by default — 매 비활성화 의 X. ## 🔗 Graph - 부모: [[React_Native]] · [[React_Native_New_Architecture]] - 변형: [[Fabric]] · [[Fabric_Renderer]] · [[TurboModules]] · [[JSI (JavaScript Interface)]] - 응용: [[Hermes]] · [[Hermes_Engine]] · [[Codegen]] - Adjacent: [[Cross-platform_Mobile_Development_Frameworks]] · [[Flutter]] ## 🤖 LLM 활용 **언제**: 매 RN 0.74+ green-field project, 매 native↔JS round-trip 의 perf bottleneck 진단, 매 Reanimated/Skia/Gesture-Handler 의 깊은 통합. **언제 X**: 매 Expo Go (legacy bridge only) 환경, 매 unmaintained native module 에 의존하는 코드베이스. ## ❌ 안티패턴 - **매 mixed arch leak**: 매 NEW_ARCH_ENABLED 의 절반만 활성화 → 매 일부 module 의 silent fallback. - **매 sync abuse**: 매 모든 호출 의 sync 화 → 매 JS thread 의 block. - **매 Codegen skip**: 매 manual binding 의 작성 — 매 type drift 의 발생. - **매 bridge pattern 재현**: 매 NativeEventEmitter 의 남용 — 매 JSI host object 의 selection. ## 🧪 검증 / 중복 - Verified (React Native 공식 docs reactnative.dev/architecture, RN 0.76 release notes 2024-10). - 신뢰도 A. ## 🕓 Changelog | 날짜 | 변경 | |---|---| | 2026-05-08 | Phase 1 | | 2026-05-10 | Manual cleanup — Bridgeless 의 JSI/Fabric/TurboModule pillars 정리 |