Instruments中常用Template的使用

 Instruments是苹果提供的Xcode套件,可用于分析iOS,MacOS程序的性能数据,进行性能提升。Instruments提供了很多类型的Template,用于特定场景的分析。这里选了3种常用的Template进行使用方法的讲解,对于其他Template的用法则用到时再了解吧,没必要一次把所有的类型都学习一遍。
讲解的Template有:
1.Time Profiler
2.Allocations
3.Leaks
 
Time耗时分析
在时间轴中拖拽两个begin-end线,分享这2根线之间的方法调用。
 
详情面板设置
Call Tree设置
通常筛选常见开启的配置方式:
1
2
3
4
5
6
7
Separate by Thread:按线程分割
Invert Call Tree:倒置调用栈
Hide System Libraries:隐藏系统库
其他按需开启
Separate by State:按状态分割
Flatten Recursion:平铺递归
Top Fuctions:顶部方法,没看出有啥作用。
单击Profile详情面板中的使用每行符号右侧的箭头,进入到当前方法内的详细调用和时间占用。
Heavlest Stack Trace操作
双击右侧Heavlest Stack Trace下的调用符号,进入到源码中方法调用的位置。

 

Allocations内存使用分析
 

概念解释

all-heap-allocations:所有堆内存分配
all-anonymous-VM:所有的虚拟内存分配
堆分配和虚拟内存分配是两回事
当应用程序启动时,操作系统为其分配一块虚拟内存块。当应用程序分配内存时,操作系统会从已经预留好的虚拟内存块中分配内存
应用程序不能控制匿名虚拟内存的大小,但可以通过优化堆分配来减少内存使用。

1
2
3
4
5
6
# Persistent: 当前内存中正在存活的对象个数
# Transient: 在内存中使用完成后,已经被销毁的对象个数
# Total: 当前存活的+已经销毁的 总个数
Persistent: 当前内存中正在存活的对象所占用的内存大小
Total Bytes: 当前存活的+已经销毁的 对象所使用的内存总大小
Persistent / Total Bytes: 当前存活的与创建对象总数的比值
 
点击Category 下某个item的右箭头,可以查看当前类的所有被创建对象的时间和大小

 

Leaks内存泄漏分析
 
红X表示有内存泄漏,点击红X查看内存泄漏。
在Leads详情面板,选择Call Tree可以查看方法调用栈。
Call Tree设置
1
2
3
Separate by Thread:按线程分割
Invert Call Tree:倒置调用栈
Hide System Libraries:隐藏系统库
通过Filter筛选工具筛选当前操作的类名,查看出现内存泄漏的方法,点击右侧箭头,进入到当前调用方法内详细查看
双击右侧Heavlest Stack Trace下的调用符号,进入到源码中方法调用的位置。



参考文章
https://juejin.cn/post/6865102561507672077
http://www.samirchen.com/use-instruments/
posted @   滴水微澜  阅读(184)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示