React Native runs JavaScript and native code that must communicate. The original architecture used an asynchronous bridge; the new architecture (JSI, TurboModules, Fabric) enables faster, synchronous communication. Understanding this clarifies React Native's behavior and performance.
The original architecture: the bridge
React Native runs:
→ a JS THREAD (your React/JS code) and the NATIVE side (UI, native modules)
→ they communicate over a BRIDGE: messages are SERIALIZED (to JSON), passed ASYNC,
and deserialized on the other side
Limitations:
✗ ASYNCHRONOUS only (can't call native synchronously)
✗ SERIALIZATION overhead; the bridge can be a BOTTLENECK with heavy traffic
✗ e.g. fast scrolling/animations passing data over the bridge → jank
