FBMemoryProfiler的使用

FBmemoryProfiler是FB开源的一款用于分析iOS内存使用和检测循环引用的工具库。
上一篇我们对FBMemoryProfiler进行了一通分析(其实是FB讲解的),那么我们怎么使用呢,接下来简单介绍一下。

安装
CocoaPods

我们只要在pod文件中添加这么一句就👌🏼了:

pod 'FBMemoryProfiler', '~> 0.1.3'

FBMemoryProfiler最低支持iOS8.0,如果你的pod文件上最低要求是6或者7的话,是无法直接安装的。所以,建议在开发分支上或者如果有多个target的话,在开发的target上添加FBMemoryProfiler。在生产的target上不需要添加FBMemoryProfiler。
配置好后执行 <code>pod install</code>,安装好后,打开对应的.xcworkspace文件就能看到对应的库。

Carthage

Carthage是迥异于CocoaPods的轻量级、非侵入式的包管理工具。FBMemoryProfiler同样支持使用Carthage来安装。
在创建的Cartfile文件中添加:

github "facebook/FBMemoryProfiler"

之后运行Carthage update --configuration Debug即可。

嵌入代码

首先,在main.m文件中添加FBRetainCycleDetector的hook,同时也要开启FBAllocationTracker的生成追踪:

#import <UIKit/UIKit.h>
#import "AppDelegate.h"
#if DEBUG
#import     <FBAllocationTracker/FBAllocationTracker.h>
#import <FBRetainCycleDetector/FBRetainCycleDetector.h>
#endif
int main(int argc, char * argv[]) {
#if DEBUG
    [FBAssociationManager hook];
    [[FBAllocationTrackerManager sharedManager] startTrackingAllocations];
    [[FBAllocationTrackerManager sharedManager] enableGenerations];
#endif
    @autoreleasepool {
        return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
    }
}

之后,我们要在AppDelegate.m的-application:didFinishLaunchingWithOptions:方法中嵌入FBMemoryProfiler的创建代码:

#import "AppDelegate.h"
#if DEBUG
#import <FBMemoryProfiler/FBMemoryProfiler.h>
#import <FBRetainCycleDetector/FBRetainCycleDetector.h>
#import "CacheCleanerPlugin.h"
#import "RetainCycleLoggerPlugin.h"
#endif
@interface AppDelegate ()
{
    FBMemoryProfiler *memoryProfiler;
}
@end

@implementation AppDelegate


- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
#if DEBUG
    memoryProfiler = [[FBMemoryProfiler alloc]initWithPlugins:@[[CacheCleanerPlugin new],[RetainCycleLoggerPlugin new]] retainCycleDetectorConfiguration:nil];
    [memoryProfiler enable];
#endif
    // Override point for customization after application launch.
    return YES;
}

其中,插件是可以不开启的,要开启的话需要创建两个文件,文件在这里Plugins章节里可以看到。如果不开启的话,实例化的方法如下:

memoryProfiler = [FBMemoryProfiler new];
[memoryProfiler enable];

插件主要是用来进行过滤、去重或者输出、存储等操作的,毕竟,如果不开启插件的话,只能通过手机、模拟器上点击屏幕来看内存泄漏,而如果自定义log插件的话,可以将捕获到的内存泄漏输出到控制台或者文件中。
比如,我们可以自定义一个RetainCycleLoggerPlugin,使用FBMemoryProfilerPluggable协议,重写memoryProfilerDidFindRetainCycles:方法:

- (void)memoryProfilerDidFindRetainCycles:(NSSet *)retainCycles
{
    if (retainCycles.count > 0) {
        NSLog(@"\nretainCycles = \n%@",retainCycles);
    }
}

当FBRetainCycleDetector找到循环引用之后,就会调用到上面的方法。
但是呢,在测试时候会返现,会输出很多无用信息,类似下边这种:

retainCycles = 
{(
        (
        "-> _testObject -> TestObject ",
        "-> _viewController -> ViewController "
    ),
        (
        "-> target -> FBMemoryProfilerViewController ",
        "-> _timer -> __NSCFTimer "
    ),
        (
        "-> UIPanGestureRecognizer ",
        "-> _internalActiveTouches -> __NSSetM ",
        "-> (null) ",
        "-> _gestureRecognizers -> (null) "
    )
)}

这样的信息,跟写的代码毫无关联,可能是系统内部的一些潜在的输出,应该类似一些临时cache之类的机制,并不会是真正的内存泄漏,对于这样的情况,我们可以将其过滤一下。过滤的代码类似于:

NSArray *filters = @[FBFilterBlockWithObjectIvarRelation([UIView class], @"_subviewCache")];
FBObjectGraphConfiguration *configuratin = [[FBObjectGraphConfiguration alloc]initWithFilterBlocks:filters shouldInspectTimers:YES];
memoryProfiler = [[FBMemoryProfiler alloc]initWithPlugins:@[[CacheCleanerPlugin new],[RetainCycleLoggerPlugin new]] retainCycleDetectorConfiguration:configuratin];
[memoryProfiler enable];

设置一个过滤数组,然后添加到FBMemoryProfiler的configuration中即可。
对于确信没有问题或者不想修改的问题,可以直接过滤。
比如:
NSArray *filters = @[FBFilterBlockWithObjectIvarRelation([UIPanGestureRecognizer class], @"_internalActiveTouches")]

运行效果
示例

综上,要集成到项目里并灵活运用,还需要更多的尝试,但这不失为一种提高工作效率的方式。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容