TTAnalyzeLoadTime
通过Mach-O文件NonlazyClassList构建动态库进行iOS load方法耗时检测
如何开始
简介
- 仓库中提供了源码以及二进制的文件,源码提供了整个AnalyzeLoadTime的全部文件
TTLoadTime.mm
,二进制文件为一个动态库(为什么提供动态库文末有介绍),动态库为尽可能提前执行Load Method Swizzling提供了可能 - 重写
_getObjc2NonlazyCategoryList
、_getObjc2NonlazyClassList
(runtime源码中有介绍),可以快速拿到全部load的所属Class以及load的IMP地址 - 防止运行环境被破坏使用
method_setImplementation
构建block执行原函数 - 寻找mach-o中的load以及Swizzle共耗时4毫秒
Podfile
要使用 CocoaPods 将 TTAnalyzeLoadTime 集成到您的 Xcode 项目中,请在 Podfile
中指定它
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'
target 'TargetName' do
pod 'TTAnalyzeLoadTime', '~> 1.0'
end
然后,运行以下命令
$ pod install
使用方法
#import <TTLoadTime/TTLoadTime.h>
printLoadCostsInfo();
2018-12-14 17:57:48.838908+0800 TTAnalyzeLoadTime_Example[10937:6344725] >> all load cost info below :
2018-12-14 17:57:48.838934+0800 TTAnalyzeLoadTime_Example[10937:6344725]
2018-12-14 17:57:48.838953+0800 TTAnalyzeLoadTime_Example[10937:6344725] PodLoadTime - 0.005083391442894936ms
2018-12-14 17:57:48.838962+0800 TTAnalyzeLoadTime_Example[10937:6344725] PodLoadTime(LoadTimer) - 0.005166628398001194ms
2018-12-14 17:57:48.838968+0800 TTAnalyzeLoadTime_Example[10937:6344725] TTViewController - 0.02345838584005833ms
2018-12-14 17:57:48.838974+0800 TTAnalyzeLoadTime_Example[10937:6344725] TTViewController(LoadTimer) - 0.005333335138857365ms
2018-12-14 17:57:48.838980+0800 TTAnalyzeLoadTime_Example[10937:6344725]
TODO
- 白名单
- 格式化打印(目前只能在控制台打印,而且打印比较粗糙)
参考文章
- https://juejin.im/post/5c0bb2e8e51d4529ee233fee 作者: CoderLin
- https://mp.weixin.qq.com/s/kL__CM3CfP_7i8Obg8qzWQ 作者: everettjf