React Native führt JavaScript- und native Code aus, die kommunizieren müssen. Die ursprüngliche Architektur nutzte eine asynchrone Bridge; die neue Architektur (JSI, TurboModules, Fabric) ermöglicht schnellere, synchrone Kommunikation. Das Verständnis hierfür erklärt React Natives Verhalten und Leistung.
Die ursprüngliche Architektur: die 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
