目標:block執行過程中,self不會釋放;執行完可以釋放。
最初
block中直接使用self會強引用。
1
2
3
|
self.myBlock = ^() { [self doSomething]; }; |
或者使用了對象的屬性
1
2
3
4
|
self.myBlock = ^() { NSString *str = _str; NSString *str2 = self.str; }; |
在這樣的情況下,self強引用block,block也持有該對象,導致循環引用。
要注意的是,只有在self強引用block的時候才會有這樣的問題。一般使用GCD或NSOperation時使用的內聯block是不會出現循環引用的。
加入weak self
1
2
3
4
|
__weak __typeof(self) weakSelf = self; self.myBlock = ^() { [weakSelf doSomething]; }; |
這樣,self持有了block,但block對self是弱引用,就不會導致循環引用了。
而在[weakSelf doSomething]過程中,self是不會釋放的,完美。
但是,如果是這樣呢?
1
2
3
4
5
|
__weak __typeof(self) weakSelf = self; self.myBlock = ^() { [weakSelf doSomething]; [weakSelf doSomething2]; }; |
在[weakSelf doSomething]和[weakSelf doSomething2]之間,self可能會被釋放掉。這可能會導致奇怪的問題。
加入strong self
1
2
3
4
5
6
|
__weak __typeof(self) weakSelf = self; self.myBlock = ^() { __strong __typeof(self) strongSelf = weakSelf; [strongSelf doSomething]; [strongSelf doSomething2]; }; |
這樣,block既沒有持有self,又能保證block在執行過程中self不被釋放,真正達到了最初的目標。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。
原文鏈接:https://segmentfault.com/a/1190000019296570