手动布局为什么比自动布局效率要高?
实际上这个问题主要是针对iOS12之前,使用AutoLayout,视图嵌套的数量对性能的影响是呈指数增长的。因为在iOS12之后,AutoLayout的性能跟手动布局已经相差很小了。
AutoLayout原理
AutoLayout用到了布局算法Cassowar算法和一整套布局引擎Layout Engine
每个视图在得到它的布局之前,Layout Engine会将视图、约束、优先级、固定大小通过计算转换成最终的位置和大小。
具体工作流程:
- 当约束变化,添加、删除视图、设置constant和priority会触发约束变化
- Layout Engine碰到约束变化时会重新计算布局
- 获取到新约束后,调用
superview.setNeedLayout()
- 然后会进入Deferred Layout Pass,主要是做一些容错处理。比如说有约束缺失或者没有确定,会在这里做容错处理
- 接下来,Layout Engine 会从上到下调用 layoutSubviews() ,通过 Cassowary 算法计算各个子视图的位置,算出来后将子视图的 frame 从 Layout Engine 里拷贝出来
- 最后,当runloop到来的时候,去重新绘制操作(这一步跟手动布局一样)
因此使用 Auto Layout 和手写布局 的区别,就是多了布局上的这个计算过程
性能问题
在iOS12之后,它是这样的:
而在此之前的 Auto Layout,视图嵌套的数量对性能的影响是呈指数级增长的。
这是因为iOS 12 之前,很多约束变化时都会重新创建一个计算引擎 NSISEnginer 将约束关 系重新加进来,然后重新计算。结果就是,涉及到的约束关系变多时,新的计算引擎需要重新计 算,最终导致计算量呈指数级增加。