UI卡顿问题

1、 监测卡顿的方式

a、Xcode 层级关系是否有异常

b、 instruments 的Animation Hitch工具检测:碰到问题,录制完了无数据(用iphone7录制有数据的,iphne14录制无数据?)

2、可能导致的卡顿的原因

a、 直播广场列表一直往下刷新内存会爆掉,可能存在内存泄漏,需要进一步看看

1、 可以用内存工具检测看看有没有异常

2、 看代码里有没有循环引用(结合撒伽师兄那天给的日志)

b、 cell上的lottie动画可能导致卡顿

c、 进一步看看还有没有其他可能导致卡顿的代码

1、 阴影、圆角设置的方式

2、 离屏渲染的问题

3、 光栅化设置

4、 图片缓存占用太多内存

5、 图片是否还有压缩的空间

6、 cell上有大量的removeFromSuperView可能导致卡顿,代码可以优化(是为了避免数据重复,在prepareForReuse里使用,可以换成在这里刷新数据???)

d、 检查是否有线程不合理问题

1、 主线程耗时任务,比如调用UIGraphicsGetCurrentContext等接口在 CPU 上进行绘制计算

2、 主线程等待繁忙的子线程或低优先级的后台线程任务而导致阻塞

3、 主线程等待系统资源,比如使用Data(contentsOf:)进行 IO 读取等

问题记录

1、preview类型数据没有自测过,记得mock数据自测

2、有recommend的数据也没自测过

待解决的问题

1、找到检测卡顿的工具 ------ instruments的animation hitch可以录制了

新发现

1、同一父视图重复调用addSubviews添加同一个View并不会产生多层级

重构心得

1、 抓住主要问题,先重构大量removeFromSuperView问题

2、 从最上层开始重构,重构玩一个单元,进行一次自测

3、 从关键方法入手分析

后记

卡顿分析相关参考文档

Instruments性能检测

https://www.jianshu.com/p/9e94e42cfb01

Animation Hitch:

https://www.jianshu.com/p/158a8497fe1c

https://juejin.cn/post/7231731488928399415

https://zhuanlan.zhihu.com/p/428971055?utm_id=0

iOS卡顿检测:

https://www.jianshu.com/p/ee62bbf38559

UICollectionView复用:

https://www.jianshu.com/p/5d817ea3565d

https://www.jianshu.com/p/e55178fd1e7f

dispatch_sync_on_main_queue:

https://www.jianshu.com/p/b3227582037d

相关推荐
菜鸟小芯4 小时前
【GLM-5 陪练式创意 UI 实战】第一篇:创意魔法盒 —— 用 AI 生成 “开心” 主题 Flutter UI,搞定深浅色与响应式
人工智能·flutter·ui
嫩嫩的猿13 小时前
android jetpack compose Model对象更新变量 UI不更新、不刷新问题
android·ui·android jetpack
LateFrames19 小时前
WinForms + OpenTK (OpenGL 3.3) 粒子动画实测:100 万粒子,流畅无压力
ui·性能优化
王码码203521 小时前
Flutter for OpenHarmony:stomp_dart_client 打造实时消息引擎(企业级 WebSocket 通信标准) 深度解析与鸿蒙适配指南
网络·websocket·网络协议·flutter·ui·华为·harmonyos
忙碌5441 天前
2026年Flutter 3.16全栈实战:从UI到后端的一体化开发革命
flutter·ui
我命由我123451 天前
Photoshop - Photoshop 工具栏(68)内容感知移动工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
MoSTChillax1 天前
Figma Make:可复用 Prompt 把设计图画“准”
前端·ui·prompt·figma
xiaoxue..2 天前
TailwindCSS:从“样式民工”到“UI乐高大师”的逆袭
前端·css·ui
没有bug.的程序员2 天前
自动化测试之魂:Selenium 与 TestNG 深度集成内核、Page Object 模型实战与 Web UI 交付质量指南
前端·自动化测试·selenium·ui·testng·page·object
赵鑫亿2 天前
ClawPanel v4.4.0 发布:AI 智能助手 + 模型兼容性修复 + UI 优化
人工智能·ui·docker·容器·qq·openclaw