IOSios developersios底层原理

__weak typeof(self) wself = self

2017-06-19  本文已影响109人  longer冯

首先我们要知道:在block内部引用的对象,系统会自动给它的引用计数器+1;然后在block执行完毕后,才会release掉这个引用;

我们在刚学会使用block的时候,在block内部使用当前对象的属性时,一般就直接引用了self关键字;
如果当前block的生命周期,是在self这个对象的生命周期内的,那么,直接使用self是不会产生什么问题的。

比如下面的代码:

  obj2.block: ^ (void) {
    [self doSomethingWithObj:self.obj1];
  }

我们来分析下几种情况:

为了解决 情况2 的需求,我们要在block中访问self弱引用,即:

__weak typeof(self) wself = self;
obj2.block: ^ (void) {
  if (wself) { // 要判断self是否存在,存在才能执行它的方法
    [wself doSomethingWithObj:wself.obj1];
  }
}

如上面,使用了弱引用,就不会影响我们在外部对self进行释放了。
但是,既然self随时可能释放,我们在block中如果想要使用self的方法,就要先判断self到底有没有被释放。

那么,问题来了:既然self在执行完doSomething后被销毁了,那么后面的doOtherthing肯定也就无法执行了,但是我们又必须让它执行起来。
这个时候,我们就要对__weak引用过的self再次进行__strong引用一遍。
代码如下:

__weak typeof(self) wself = self;
obj2.block: ^ (void) {
  __strong typeof(wself) sself = wself; 
  if (sself) { // 要判断self是否存在,存在才能执行它的方法
    [sself doSomething];
    // ... n秒后
    [sself doOtherthing];
  }
}

在block中,再执行一遍__strong typeof(wself) sself = wself;后,self就不会立马被销毁了,就可以顺利执行完毕doSomethingdoOtherthing,然后在block执行完毕后再销毁self对象。

本人水平有限,这种情况我也测试不出来,希望有测试过这种情况的同学可以分享一下结果给我!我将感激不尽!!

上一篇 下一篇

猜你喜欢

热点阅读