AutoLayout原理

手动布局为什么比自动布局效率要高?

实际上这个问题主要是针对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之后,它是这样的:


iOS优化后

而在此之前的 Auto Layout,视图嵌套的数量对性能的影响是呈指数级增长的。
这是因为iOS 12 之前,很多约束变化时都会重新创建一个计算引擎 NSISEnginer 将约束关 系重新加进来,然后重新计算。结果就是,涉及到的约束关系变多时,新的计算引擎需要重新计 算,最终导致计算量呈指数级增加。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Autolayout 介绍 自动布局区别于手动布局frame的一种布局技术,主要是为元素添加一些关于位置的相对约束...
    草莓味辣妹阅读 655评论 0 0
  • 视图更新和渲染循环(render loop)有关,工作流程如下图: 主要分三步: 更新约束,从下往上,最终到达Wi...
    楼上那只猫阅读 679评论 0 0
  • 1.1 AutoLayout原理 iOS 中视图所需要的布局信息只有两个,分别是 origin/center 和 ...
    Claire_wu阅读 19,463评论 3 27
  • 翻译自“Auto Layout Guide”。 1 入门 1.1 理解自动布局 自动布局根据视图层级结构中视图上的...
    lakerszhy阅读 3,892评论 3 26
  • 1. AutoLayout的核心 苹果公司推出的AutoLayout,是一个基于约束,动态计算视图大小和位置的库,...
    冰风v落叶阅读 2,063评论 0 3

友情链接更多精彩内容