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

简单谈谈ios开发中的UI

UITableView

重用机制

let cell = tableView.dequeueReusableCell(withIdentifier: cellReuseID, for: indexPath)

UITableView 内部维护了一个 重用缓存池

核心流程

  1. 缓存池结构:字典形式: key = 重用标识符,value = 闲置的 cell

  2. cell 滑出屏幕:系统自动把它扔进缓存池,标记为「可重用」;

  3. 需要新 cell:调用 dequeueReusableCell 方法

    优先去缓存池找对应重用标识符的闲置 cell,找到直接复用,没找到系统进行创建

  4. 重用标识符:唯一标识一种 cell 样式

UI数据源同步问题

在实际的设计中,我们经常会遇到多线程竞态问题,比如请求server的数据,这需要放到子线程来进行,但是在等待server返回的过程中,UITableView的数据有可能会被修改,server返回后再刷新UI就会出现已经修改的数据重置的问题,实际解决方案一般有两种

  1. 串行队列 设计一个串行队列,对于UI数据的操作放到串行队列去做即可

  2. 并发访问 数据拷贝 我们为子线程拷贝一份主线程的数据,当主线程对数据进行修改的时候,记录一下,然后当server数据返回时让其做同步修改即可

UI事件传递

UIView和CALayer

UIView为其提供内容,处理触摸等事件,参与响应链

CALayer负责显示内容contents

这体现了单一职责原则

事件传递和视图响应链

事件传递流程

🔥 传递方向:从上到下

传递顺序:点击屏幕 → UIApplication → UIWindow → 控制器根视图 → 父视图 → 子视图(倒序遍历,也就是说最后被添加的子视图最先响应)

note:对于每个子视图,先调用 pointInside 判断点是否在视图内,再递归调用子视图的 hitTest

point(inside:with:) 判断触摸点是否在当前视图范围内 hitTest(_:with:) 寻找并返回最终的响应视图
视图响应链

🔥 传递方向:从下往上

传递顺序:最佳响应视图 → 父视图 → ... → 控制器根视图 → UIViewController → UIWindow → UIApplication → AppDelegate

最佳视图重写 touchesBegan,touchesMove,touchedEnded方法 → 自己处理,事件终止(如果不重写,会一直向上抛,直到最顶层都不处理,该事件丢弃)

图像显示原理

UIView 本身不负责绘制和显示,真正负责像素显示、渲染、动画的是它的底层属性:CALayer。

iOS 屏幕显示是一套固定的流水线作业,分为 3 个阶段:CPU 预处理 → GPU 硬件渲染 → 屏幕刷新显示

CPU的工作

  • 布局计算:计算所有视图的 frame、AutoLayout 约束、文字宽高,确定视图位置大小

  • CPU绘制位图:如果你重写了 drawRect:,CPU 会进行软件绘制,生成位图

  • CPU 把所有图层、位图数据打包,通过Core Animation框架IPC 通信提交给 GPU的OpenGL管线

GPU的工作

顶点着色,图源装配,光栅化,片段着色,片段处理

提交像素点到帧缓冲区中

屏幕显示

手机屏幕默认 60Hz 刷新率(每 16.7ms 刷新一次)

屏幕发出 VSync(垂直同步信号),系统从帧缓冲区取出渲染好的画面,电子枪逐行扫描屏幕,显示像素,完成一帧显示,循环往复

UI掉帧

在规定的16.7ms内,在下一帧VSync信号到来之前,CPU和GPU并没有完成下一帧画面的合成

滑动优化方案

解决主线程卡顿

  1. 所有耗时操作全部丢子线程

  2. 图片子线程预解码,主线程只赋值展示

  3. 列表优先用 reloadRows 局部刷新,少用 reloadData

  4. 简化约束,复杂布局尽量用 Frame

  5. 提前初始化复用控件,不要滑动时临时创建 解决 GPU 渲染掉帧

  6. 尽量少用 圆角 + masksToBounds,避免离屏渲染

  7. 阴影一定要加 shadowPath,避免实时计算

  8. 减少视图嵌套,扁平化 UI 层级

  9. 删掉无用透明重叠 View,减少过度绘制

  10. 非必要不使用模糊、蒙版

UIView绘制原理

异步绘制

UIView 默认就是自己底层 layer 的 delegate,CALayer 绘制内容时,会优先询问代理:- (void)displayLayer:(CALayer *)layer;只要实现了这个方法,系统就不会走默认的主线程 drawRect:

该方法负责代理生成对应的位图,并生成对应的CGImage,并且设置其为Layer.contents属性的值

时序图

离屏渲染

在屏渲染:GPU的渲染操作在当前用于显示的屏幕缓冲区进行,画完直接等屏幕刷新显示

离屏渲染:GPU在当前屏幕缓冲区外新开辟一个缓冲区进行渲染操作,这就需要进行中转绘制 + 拷贝

何时触发

  1. 图层圆角 + maskToBounds

  2. 图层蒙版 || 阴影

  3. 光栅化

  4. 渐变叠加

debug

顶部菜单 Debug → Show Debug Settings

Color Offscreen - Rendered Yellow 界面黄色区域 = 正在发生离屏渲染

http://www.jsqmd.com/news/864455/

相关文章:

  • 终极指南:OBS Mac虚拟摄像头插件的完整使用教程
  • 使用Nodejs和Taotoken构建一个简单的AI对话服务端应用
  • 2026年4月惠州市专利申请机构推荐,这些做得好别错过,高新企业申报/惠州市商标申请,惠州市专利申请企业哪家好 - 品牌推荐师
  • 3分钟掌握R3nzSkin:英雄联盟国服免费全皮肤终极方案
  • OpenPLC Editor:开源工业自动化编程的完整解决方案
  • 企业级应用整合大模型时如何利用Taotoken实现成本与稳定性管控
  • rk3576 sai tdm调试
  • NotebookLM可信度评估:从论文级可信论证到生产环境SLA保障——一位首席AI架构师的11年踩坑笔记(含3份脱敏审计日志)
  • 2026 全网超详细网络安全学习路线,零基础一步步成长为实战专家,全套免费教程
  • 2026年全网最全降AI率保姆级教程:高效降低AI! - 降AI实验室
  • 咖啡一杯,Token 无限,Real-Time Cafe 深圳站来了!新增「硬件晒晒桌」与「AI 桌游试玩桌」
  • 使用嘉立创EDA画PCB板时,布线遇到“违反DRC规则,请注意白色边框”问题的解决办法
  • 如何高效破解Cursor Pro限制:5步激活AI编程助手的终极方案
  • 网盘直链解析神器:八大平台免登录高速下载终极解决方案
  • QMCDecode:3步解锁你的QQ音乐加密文件
  • 宣城有实力的网络公司推荐
  • RLVR 技术深挖:强化学习微调大模型的范式转变与代码实战
  • 2026 年 AI 工具聚合站:从模型入口到开发基础设施的进化之路
  • UART 通信学习笔记
  • SMUDebugTool:5步掌握AMD Ryzen处理器深度调试与性能优化
  • 答辩加分秘籍!长江学者特聘教授专属PPT定制
  • 抖音批量下载完整指南:3步实现无水印视频高效获取
  • 2026 降AI率网站实测盘点:真实体验分享,毕业党救急宝典
  • My-TODOs:跨平台桌面待办清单,解放您的生产力
  • 122、神经网络控制:RBF神经网络与自适应控制
  • 如何用Python实现不可见的数字版权保护:BlindWaterMark盲水印技术深度解析
  • 如何高效使用OBS源独立录制:5大创新策略指南
  • 如何5分钟创建专业清华学术PPT:终极免费模板指南
  • 网络安全渗透测试全攻略,吃透各类系统漏洞核心知识
  • 3分钟掌握微博图片批量下载:weiboPicDownloader终极指南