基于汇编实现 hook objc_msgSend,统计方法耗时的方案

文章目录


简介

首先,iOS 中进行 hook 的方案有多种,这里使用的是 Facebook 的 fishhook 库:Github:fishhook

hook objc_msgsend ,货拉拉技术团队已有完善的方案:基于汇编实现objc_msgSend hook方法耗时的方案

另外,它们还开源了基于fishhook、汇编 hook objc_msgsend 并支持方法耗时可视化的项目:hll-wp-guldan-ios

接入

首先在 Podfile 中添加:

cpp 复制代码
pod 'Guldan', :git => "https://github.com/HuolalaTech/hll-wp-guldan-ios.git"

然后设置要监控的代码片段:

objectivec 复制代码
[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)。

相关推荐
笑尘pyrotechnic4 小时前
LLDB进阶:使用命令行进行检查
ios·objective-c·cocoa·lldb
z***y8627 小时前
Swift在iOS中的Xcode
ios·xcode·swift
AirDroid_cn7 小时前
iOS 18 后台应用偷跑流量,如何限制?
macos·ios·cocoa
u***42079 小时前
macOs安装docker且在docker上部署nginx+php
nginx·macos·docker
明君8799710 小时前
Flutter 图纸标注功能的实现:踩坑与架构设计
android·ios
江东小bug王10 小时前
深入理解 UINavigationController:生命周期、动画优化与性能调优
ios
Lexiaoyao2011 小时前
Apple StoreKit 2 开发指南
ios·apple
心灵宝贝21 小时前
Mac Unity 2018.dmg游戏工具 安装步骤 简单易懂教程(附安装包)
macos·unity·游戏引擎
2501_915106321 天前
iOS App 测试工具全景分析,构建从开发调试到线上监控的多阶段工具链体系
android·测试工具·ios·小程序·uni-app·iphone·webview
学习非暴力沟通的程序员1 天前
Mac 自动定时打开指定URL(无日历版)操作文档
macos