iOS应用性能监控:Pre-Main与Main函数耗时分析及Time Profiler使用教程

一、查看耗时

(1)查看Pre-Main()阶段花费的总时间

想查看Pre-Main阶段的时间比较简单。

直接打开Xcode,找到 Product-> Scheme-> Edit Scheme-> Run-> Arguments-> Environment Variables-> DYLD_PRINT_STATISTICS 设置为 YES

Run一下,就能看到pre-Main的耗时日志啦~

(2)查看Main()函数后的花费时间

查看Main函数之后的耗时,目前有两种方案:

  • 方案一:定时抓取主线程方法的调用堆栈,计算一段时间里的方法耗时。( Xcode 中的 Time Profiler 就是使用的这种的方法)

  • 方案二:对 objc_msgSend 方法进行 hook,来得到所有方法的耗时。

注: hook 是指在原有方法开始执行时,换成你指定的方法(用 RuntimeMethod Swizzle / Facebook开源的fishhook框架)。或在原有方法的执行前后,添加执行你指定的方法。从而达到改变指定方法的目的。

使用方案一的 TimeProfiler 查看 Main 函数后耗时,方法如图:

除了Xcode自带的Time Profiler,开发者还可以使用KeyMob等第三方工具进行更全面的iOS性能监控。KeyMob提供实时监控CPU、GPU、内存、FPS、网络和能耗等性能指标,支持图表展示,帮助开发者更便捷地分析和优化应用性能。

二、Time Profiler的基本使用

  • 第一步,打开工程,连接 真机

(PS:一定要用真机调试,因为模拟器使用的是电脑的CPU,并不能检测出真正的性能问题。)

  • 第二步,打开 XcodeProduct -> Profile

  • 第三步,选择 Time Profiler

  • 第四步,这时,你会看到Time Profiler的界面。具体说明如下:

  • 第五步,根据自己的需要,配置一下 Call Tree

注:

1 . Separate by State:按状态分开,分析数据。

2 . Separate by Thread:按线程分开,分析数据。可找出严重消耗资源的线程,特别对于处理和渲染UI的主线程,一旦主线程受到阻塞,一定会造成App的卡顿。

3 . Invert Call Tree:反向显示调用树。把调用层级最深的方法显示在最上面。

4 . Hide System Libraries:隐藏系统级的干扰信息。

5 . Flatten Recursion:合并递归。

6 . Top Functions:置顶耗时方法。

  • 第六步,找到耗时的方法,并进行针对性优化。
相关推荐
小猫爱游戏1 小时前
theone陪伴ai手机版免费版下载安装教程附带最新邀请码theone陪伴ai设定教程接入下载使用教程手机版安卓版app鸿蒙版苹果版IOS电脑版安装包下载地址
android·人工智能·智能手机·theone陪伴ai·theone陪伴ai下载·免费下载安装·接入微信教程
韩曙亮1 小时前
【Android】Android 源码查看 ( Android 源码在线查看 2026-03-30 | Android 源码下载 | Android 源码查看工具 )
android·安卓·安卓源码·aosp·android 源码·android源码查看工具·android 源码工具
dora1 小时前
从dorachat-auth的角度看登录认证
android
zyl837212 小时前
Express快速上手
https·node.js·express
Fate_I_C2 小时前
View Binding的基础使用
android·kotlin·viewbinding
zhangphil2 小时前
Android Coil 3 extend ImageRequest‘s custom method/function,Kotlin
android·kotlin
星河漫步Lu2 小时前
QT6中五步完成Android的环境配置
android·qt
UXbot3 小时前
AI 原型工具对比(2026):从文字描述到完整 App 界面的 5 款主流平台评测
android·前端·ios·交互·软件构建
StarChainTech3 小时前
先享后付,正在悄悄改变电商的“信任游戏”
大数据·人工智能·游戏·微信小程序·小程序·软件需求