.2.2 递归的Diffing在1.2节中的虚拟DOM对象中可以得知: 虚拟DOM树的每个节点通过 children 属性构成了一个嵌套的树结构, 这意味着要以递归的形式遍历和比较新旧虚拟DOM树.2.1...节的策略解决了Diffing算法的时间复杂度的问题, 但我们还面临着另外一个重大的性能问题——浏览器的渲染线程和JS的执行线程是互斥的, 这意味着DOM节点过多时, 虚拟DOM树的构建和处理会长时间占用主线程..., 将待调用的函数加入执行队列, 浏览器将在不影响关键事件处理的情况下逐个调用.考虑到浏览器的兼容性以及 requestIdleCallback 方法的不稳定性, React自己实现了专用于React的类似..., 同时具备以下特性:可暂停、可恢复的更新;可跳过的重复性、覆盖性更新;具备优先级的更新.对于递归形式的程序来说, 这些是难以实现的....于是就需要一个处于递归形式的虚拟DOM树上层的数据结构, 来辅助完成这些特性.这就是React16引入的重构后的算法核心——Fiber.3.