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

相关推荐
我命由我1234514 小时前
Photoshop - Photoshop 工具栏(57)模糊工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
百万彩票中奖候选人15 小时前
在trae、qoder、Claude Code、Cursor等AI IDE中使用ui-ux-pro-max-skill
人工智能·ui·ux
Aevget19 小时前
Kendo UI for jQuery 2025 Q4新版亮点 - AI 助手持续加持,主力开发更智能
人工智能·ui·jquery·界面控件·kendo ui
小雨下雨的雨21 小时前
Flutter跨平台开发实战: 鸿蒙与循环交互艺术:无限循环的 Banner 引擎
flutter·ui·华为·交互·harmonyos·鸿蒙系统
W***r261 天前
服务器处理请求:服务器解析请求并返回响应
ui
工业HMI实战笔记1 天前
拯救HMI×施耐德电气|以AI重塑工业人机交互新范式
人工智能·ui·信息可视化·自动化·人机交互·交互
AI陪跑1 天前
AI助力搭建 ant design 6 的 可视化编辑UI设计器
ui
小雨下雨的雨1 天前
Flutter跨平台开发实战: 鸿蒙与循环交互艺术:ListView 的视口循环与内存复用
flutter·ui·华为·交互·harmonyos·鸿蒙系统
向上的车轮1 天前
Zed 项目GPUI :用 Rust + GPU 渲染的现代化 UI 框架
开发语言·ui·rust
豆几的窝1 天前
230+效率功能2026AI插件脚本大合集V7.0最新中文版支持Illustrator 2026-CS6 Win/Mac
ui·illustrator