RN 47 初始化 Bridge 过程

- (instancetype)initWithDelegate:(id<RCTBridgeDelegate>)delegate
                       bundleURL:(NSURL *)bundleURL
                  moduleProvider:(RCTBridgeModuleListProvider)block
                   launchOptions:(NSDictionary *)launchOptions
{
  if (self = [super init]) {
    _delegate = delegate;
    _bundleURL = bundleURL;
    _moduleProvider = block;
    _launchOptions = [launchOptions copy];

    [self setUp];
  }
  return self;
}

其中 delegate 是 nil。主要的过程在 setUp 里。

setUp 过程

  Class bridgeClass = self.bridgeClass;
  self.batchedBridge = [[bridgeClass alloc] initWithParentBridge:self];
  [self.batchedBridge start];

主要是找到 Bridge 对应的类,然后初始化,然后调用 Bridge 的 start 函数。

找到 Bridge 对应的类

- (Class)bridgeClass
{
  // In order to facilitate switching between bridges with only build
  // file changes, this uses reflection to check which bridges are
  // available.  This is a short-term hack until RCTBatchedBridge is
  // removed.

  Class batchedBridgeClass = objc_lookUpClass("RCTBatchedBridge");
  Class cxxBridgeClass = objc_lookUpClass("RCTCxxBridge");

  Class implClass = nil;

  if ([self.delegate respondsToSelector:@selector(shouldBridgeUseCxxBridge:)]) {
    if ([self.delegate shouldBridgeUseCxxBridge:self]) {
      implClass = cxxBridgeClass;
    } else {
      implClass = batchedBridgeClass;
    }
  } else if (cxxBridgeClass != nil) {
    implClass = cxxBridgeClass;
  } else if (batchedBridgeClass != nil) {
    implClass = batchedBridgeClass;
  }

  RCTAssert(implClass != nil, @"No bridge implementation is available, giving up.");
  return implClass;
 }

可以简化为看有没有 RCTCxxBridge 这个类,然后看下有没有 RCTBatchedBridge 这个类。最终结果是 RCTCxxBridge 这个类。
因为 RCTCxxBridge 是 C++ 文件,所以要加入 -lc++ 的编译选项。

初始化 RCTCxxBridge

_pendingCalls = [NSMutableArray new];
_displayLink = [RCTDisplayLink new];

[RCTBridge setCurrentBridge:self];

初始化了一个数组,存储的是 dispatch_block_t
创建了一个 RCTDisplayLink,即一个定时器,定时调用 _jsThreadUpdate 函数。
设置 RCTBridgeRCTCurrentBridgeInstance 是刚刚生成的实例。

调用 start 函数

开启一个 JS 线程,命名为 com.facebook.react.JavaScript

  _jsThread = [[NSThread alloc] initWithTarget:self
                                      selector:@selector(runJSRunLoop)
                                        object:nil];
  _jsThread.name = RCTJSThreadName;
  _jsThread.qualityOfService = NSOperationQualityOfServiceUserInteractive;
  [_jsThread start];

初始化不能被延迟初始化的 Native 模块。

  [self _initModulesWithDispatchGroup:prepareBridge];

.....
加载 JS Bundle 中的代码

[self loadSource:^(NSError *error, NSData *source, int64_t sourceLength) {

执行代码

[strongSelf executeSourceCode:sourceCode sync:NO];
时间: 2024-10-16 07:33:15

RN 47 初始化 Bridge 过程的相关文章

Java 类的实例变量初始化的过程 静态块、非静态块、构造函数的加载顺序

Java 类的实例变量初始化的过程 静态块.非静态块.构造函数的加载顺序 先看一道Java面试题: 1 public class Baset { 2 private String baseName = "base"; 3 // 构造方法 4 public Baset() { 5 callName(); 6 } 7 // 成员方法 8 public void callName() { 9 // TODO Auto-generated method stub 10 System.out.p

Dubbo中消费者初始化的过程解析

首先还是Spring碰到dubbo的标签之后,会使用parseCustomElement解析dubbo标签,使用的解析器是dubbo的DubboBeanDefinitionParser,解析完成之后返回BeanDefinition给Spring管理. 服务消费者端对应的是ReferenceBean,实现了ApplicationContextAware接口,Spring会在Bean的实例化那一步回调setApplicationContext方法.也实现了InitializingBean接口,接着会

JAVA 对象初始化的过程

对象初始化的过程例:Student S    =    new Student();1.因为new Student()用到了Student类,所以会把它从硬盘上加载进入内存2.如果有static静态代码块就会随着类的加载而执行,还有静态成员和普通方法也会随着类的加载而被加载3.在堆中开辟空间,分配内存地址4.在堆中建立对象特有属性,并同时对特有属性进行默认初始化5.对属性进行显示初始化6.执行构造代码块,对所有对象进行初始化7.执行对应的构造函数,对对象进行初始化8.将内存地址给S(给栈中的变量

kernel及系统初始化的过程

1.Kernel初始化的过程: a.设备探测 b.驱动初始化(可能会从initrd(initramfs)文件中装载驱动模块) c.以只读挂载根文件系统: d.装载第一个进程init(PID:1) e.int进程的配置文件/etc/inittab f./etc/inittab文件的格式 id:runlevels:action:process id: 标识符 runlevels: 在哪个级别运行此行 action: 在什么情况下执行此行 process: 要运行程序 action: initdefa

JVM内存模型及对象在内存中初始化的过程

JVM内存模型 Java虚拟机所管理的内存区域,也称为运行时数据区,分为以下几个运行时数据区,如图所示 程序计数器:当前程序所执行字节码的行号指示器 程序计数器(Program Counter Register)是一块较小的内存空间,可以看作是当前线程所执行的字节码的行号指示器.在虚拟机的概念模型里,字节码解释器工作时就是通过改变这个计数器的值来选 取下一条需要执行的字节码指令,分支.循环.跳转.异常处理.线程恢复等基础功能都需 要依赖这个计数器来完成. Java虚拟机的多线程是是通过线程轮流切

对象初始化的过程

对象初始化过程: a.在创建类之前,检查类是否已加载(检查硬盘上的class文件,是否已加载到内存中),如果没有加载就先加载父类文件,再加载本类的文件        Java使用的加载策略:懒惰式加载(按需要加载),用到的时候加载,只加载一次 b.分配对象的空间,递归分配所有的父类和子类的属性空间  属性会自动初始化为"0"值 c.给属性赋值 d.调用父类的构造方法(默认调用父类的无参构造方法) e.调用本类的构造方法

WinMain初始化详细过程以及消息循环

主要内容:详细介绍WinMain函数的初始化过程以及消息循环 1.窗口类定义 通过给窗口类数据结构WNDCLASS赋值完成, 该数据结构中包含窗口类的各种属性 <1>LoadIcon 作用:在应用程序中加载一个窗口图标 原型:HICON LoadIcon(HINSTANCE hInstance, LPCTSTR lpIconName) //第一个参数为图标资源所在的模块句柄, //指向用户所加载图标的那个窗口 //若为NULL则使用系统预定义图标 //第二个参数为图标资源名或系统预定义图标标识

HashMap初始化容量过程

集合是Java开发日常开发中经常会使用到的,而作为一种典型的K-V结构的数据结构,HashMap对于Java开发者一定不陌生.在日常开发中,我们经常会像如下方式以下创建一个HashMap: Map<String, String> map = new HashMap<String, String>(); 但是,大家有没有想过,上面的代码中,我们并没有给HashMap指定容量,那么,这时候一个新创建的HashMap的默认容量是多少呢?为什么呢?本文就来分析下这个问题. 什么是容量 在J

SSH项目在服务器上初始化的过程

刚接触ssh项目的时候,只知道照着demo写,出现问题了就百度,解决了就沾沾自喜,现在尝试着做一些总结,提升下自己. 一个简单的ssh项目是怎么在服务器上部署(deploy),服务器又是怎么加载实例化项目代码了? 项目在Tomcat发布之后,Tomcat会加载这个项目到webapps目录,run,仔细看下Console上的日志发现,Tomcat先检查jar包,然后加载web.xml. 默认加载顺序为<context-param>---<listener>---<filter&