当前位置: 首页 > news >正文

React native新架构组成

React Native 的新架构(New Architecture)引入了一些新的组件和概念,旨在提高性能、增强灵活性和简化跨平台开发。主要组成部分包括:

Fabric:

Fabric Renderer: Fabric 是新的渲染引擎,它旨在取代现有的渲染引擎。与现有渲染引擎相比,Fabric 更高效,并且能够更好地支持异步渲染。
Concurrent Rendering: Fabric 支持并发渲染,使得 React 能够在后台异步计算组件树,并在主线程有空闲时进行渲染。这种方式可以显著提高应用的响应速度和流畅度。
Direct Communication: Fabric 允许更直接的通信途径,从而减少 JavaScript 和原生代码之间的桥接开销。

TurboModules:

TurboModules: 这是新的模块系统,旨在取代现有的原生模块系统。TurboModules 通过 JSI(JavaScript Interface)直接访问原生代码,减少了桥的开销,提供了更高效的模块调用。
Lazy Loading: TurboModules 支持懒加载,仅在需要时加载模块,从而减少启动时间和内存使用。
JSI (JavaScript Interface):

JSI Bridge:

JSI 是一层新的接口,取代了现有的桥接机制。它允许 JavaScript 代码直接调用 C++,以及 C++ 直接调用 JavaScript 函数。这种方式提高了性能和灵活性。
Direct Memory Access: JSI 允许 JavaScript 直接访问内存中的数据,而无需通过桥进行序列化和反序列化。

Codegen:

Code Generation: Codegen 是一个工具,用于自动生成 JavaScript 和原生代码之间的绑定代码。这使得跨平台开发更加方便,并且减少了手动编写绑定代码的错误风险。
Type Safety: Codegen 利用 TypeScript 和 Flow 提供的类型系统,确保生成的代码类型安全,减少运行时错误。

Hermes:

Hermes Engine: Hermes 是一个优化的 JavaScript 引擎,专为 React Native 应用设计。它可以显著减少应用的启动时间和内存使用。
Ahead-of-Time Compilation (AOT): Hermes 支持 AOT 编译,将 JavaScript 代码提前编译成字节码,从而提高执行效率。

总结

React Native 新架构的主要部分包括:

Fabric: 新的渲染引擎,支持并发渲染和更直接的通信。
TurboModules: 新的模块系统,通过 JSI 提供更高效的模块调用。
JSI (JavaScript Interface): 新的接口层,允许 JavaScript 和 C++ 之间的直接调用。
Codegen: 自动生成 JavaScript 和原生代码之间的绑定代码。
Hermes: 一个优化的 JavaScript 引擎,支持 AOT 编译。
这些改进旨在提高 React Native 应用的性能、增强开发体验和简化跨平台开发。

http://www.lryc.cn/news/377773.html

相关文章:

  • Spring Security+Spring Boot实现登录认证以及权限认证
  • 5款堪称变态的AI神器,焊死在电脑上永不删除!
  • Python和OpenCV图像分块之图像边长缩小比率是2
  • C语言中的位域(bit-field)是什么,以及它的用途和优缺点
  • 从面试角度了解前端基础知识体系
  • 【DKN: Deep Knowledge-Aware Network for News Recommendation】
  • Linux管道与重定向
  • kotlin数组
  • SpringSecurity实战入门——认证
  • 23种设计模式之桥接模式
  • vuejs3+elementPlus后台管理系统,左侧菜单栏制作、跳转、默认激活菜单
  • 代码随想录算法训练营第四十四天|LeetCode198 打家劫舍、LeetCode213 打家劫舍Ⅱ
  • Git进阶使用(图文详解)
  • Effective C++ 改善程序与设计的55个具体做法笔记与心得 4
  • WordPress管理员后台登录地址修改教程,WordPress admin登录地址文件修改方法
  • Python基础教程(二十四):日期和时间
  • java面向对象(上)
  • 揭示SOCKS5代理服务器列表的重要性
  • 机器学习python实践——关于ward聚类分层算法的一些个人心得
  • 从零制作一个docker的镜像
  • eclipse 老的s2sh(Struts2+Spring+Hibernate) 项目 用import导入直接导致死机(CPU100%)的解决
  • 《米小圈动画汉字》汉字教育动画化:传统与创新的完美融合!
  • 【LeetCode最详尽解答】11-盛最多水的容器 Container-With-Most-Water
  • redis 缓存jwt令牌设置更新时间 BUG修复
  • nginx精准禁止特定国家或者地区IP访问
  • 单片机课设-基于单片机的电子时钟设计(仿真+代码+报告)
  • .net 6 api 修改URL为小写
  • Windows电脑部署Jellyfin服务端并进行远程访问配置详细教程
  • rsync同步目录脚本
  • LeetCode 6. Z 字形变换