Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/maniackk/TimeProfiler
Recording all OC methods in the main thread takes time
https://github.com/maniackk/TimeProfiler
Last synced: 2 months ago
JSON representation
Recording all OC methods in the main thread takes time
- Host: GitHub
- URL: https://github.com/maniackk/TimeProfiler
- Owner: maniackk
- License: mit
- Created: 2019-06-26T08:21:07.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-08-10T11:51:46.000Z (over 1 year ago)
- Last Synced: 2024-08-03T18:19:59.898Z (6 months ago)
- Language: Objective-C
- Homepage: https://juejin.im/post/5d146490f265da1bc37f2065
- Size: 5.21 MB
- Stars: 373
- Watchers: 5
- Forks: 68
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- Awesome-iOS - TimeProfiler - Recording all OC methods in the main thread takes time (Tools)
README
# TimeProfiler
Recording all OC methods in the main thread takes time> 大家对TimeProfiler有什么建议或者需求或遇到crash等所有事情,强烈欢迎到[Issues](https://github.com/maniackk/TimeProfiler/issues)去留言。
# 更新计划
**目前已经支持显示调用堆栈。**
**支持super函数的统计**
**重大更新:仿照os_signpost,用户在一个功能的开始调用TPStartTrace,在结束地方调用TPStopTrace。具体用法见下面👇**
## 1.1版本:增加耗时方法排序功能和耗时方法中调用次数排序功能(已做)![pic](https://wukaikai.tech/images/tuchuang/tpjj.png)
## 1.2版本:优化代码质量和性能问题(未做)
## 1.3版本:增加打印卡顿时候,所有线程堆栈 (未做)# 特性
1. 记录所有在主线程运行的OC方法的耗时情况
2. 支持设置记录的最大深度和最小耗时
3. 显示调用堆栈
4. 支持super函数的统计
5. 支持在程序中多次监控,类似os_signpost# 支持机型
iPhone5s及更新真机(arm64)# 用法
## 启动监控```
//一个函数耗时统计
- (void)viewDidLoad {
[[TimeProfiler shareInstance] TPStartTrace:"大卡页的viewDidLoad函数"];
...
[[TimeProfiler shareInstance] TPStopTrace];
}
//一个页面/功能点的耗时统计
[[TimeProfiler shareInstance] TPStartTrace:"详情页"];
/* 中间可以跨多个函数或模块*/
[[TimeProfiler shareInstance] TPStopTrace];
/**
开始/停止统计,需成对使用
可以用来测多个功能点的耗时问题
*/
- (void)TPStartTrace:(char *)featureName;
- (void)TPStopTrace;- (void)TPSetMaxDepth:(int)depth; //默认3;不调用的话,默认是3
- (void)TPSetCostMinTime:(uint64_t)time; //单位为us,1ms = 1000us;不调用的话,默认是1000us
- (void)TPSetFilterClass:(NSArray *)classArr; //需要过滤的类,不调用此方法,默认为TimeProfilerVC、TPRecordHierarchyModel、 TPRecordCell、TPRecordModel等TimeProfiler本身类(不统计过滤的类)
```把TimeProfiler文件夹放入项目中,run App后,摇一摇App,就可以看到主线程运行的OC方法的耗时情况
# 原理介绍
[博客](https://juejin.im/post/5d146490f265da1bc37f2065)