基于汇编实现 hook objc_msgSend,统计方法耗时的方案
文章目录
- 简介
- 接入
简介
首先,iOS 中进行 hook 的方案有多种,这里使用的是 Facebook 的 fishhook 库:Github:fishhook
hook objc_msgsend ,货拉拉技术团队已有完善的方案:基于汇编实现objc_msgSend hook方法耗时的方案
另外,它们还开源了基于fishhook、汇编 hook objc_msgsend 并支持方法耗时可视化的项目:hll-wp-guldan-ios
接入
首先在 Podfile 中添加:
pod 'Guldan', :git => "https://github.com/HuolalaTech/hll-wp-guldan-ios.git"
然后设置要监控的代码片段:
[GDNOCMethodTimeProfiler start];
// 下载图片
[self downloadImages];
[GDNOCMethodTimeProfiler stop];
[GDNOCMethodTimeProfiler handleRecordsWithComplete:^(NSArray<NSString *> * _Nonnull filePaths) {
// file path
for (NSString *filePath in filePaths) {
NSLog(@"File path: %@", filePath);
}
}];
从控制台拿到 path:
最后将 path 的文件拖入 chrome://tracing/ :
经测试,模拟器(arm64)和真机均支持,不支持模拟器(x86_64)。