NSTimer retain了它的target

今天一直在释放一个类对象B(这个类中有一个timer),根据arc的原理来说, B的retainCount为0时,就会调用dealloc。但是当为我把B=nil,没有进入dealloc。

-(void)dealloc

{

  [timer invalidate];

     timer = nil;

}

后来经过朋友提醒知道,nstimer对B类有引用,也就是在初始化时对target有retain.

    timer = [NSTimer scheduledTimerWithTimeInterval:1.0 self selector:@selector( logout: ) userInfo:nil repeats:YES];

 后来把self改为__weak,发现也不行。

    __weak id weakSelf = self;

    timer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:weakSelf selector:@selector( logout: ) userInfo:nil repeats:YES];

 最终在stackoverflow里面找到了一种使用代理的方法。

http://stackoverflow.com/questions/16821736/weak-reference-to-nstimer-target-to-prevent-retain-cycle

单独建立一个WeakTimerTarget

@interface WeakTimerTarget : NSObject

{

    __weak id target;

    SEL selector;

}

-(id)initWithTarget:(id)tg selector:(SEL)sel;

- (void)timerDidFire:(NSTimer *)timer;

@end

@implementation WeakTimerTarget

 

-(id)initWithTarget:(id)tg selector:(SEL)sel

{

    self     =  [super init];

    target   = tg;

    selector = sel;

    return self;

}

 

- (void)timerDidFire:(NSTimer *)timer

{

    if(target)

    {

        [target performSelector:selector withObject:timer];

    }

    else

    {

        [timer invalidate];

    }

}

@end

在B类中这样使用:

 WeakTimerTarget *weakTarget = [[WeakTimerTarget alloc] initWithTarget:self selector:@selector(logout:)];

 [NSTimer scheduledTimerWithTimeInterval:1.0 target:weakTarget selector:@selector( timerDidFire: ) userInfo:nil repeats:YES];

 

这样就可以解决不能释放内存的问题了,但是为什么使用__weak self 和 __strong self效果是一样的还不知道为什么,希望大家指教。

转载于:https://www.cnblogs.com/someone617-blog/p/4143845.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值