在block中,所有参与的对象都会被自动retain count+1。本来是在类A中使用了一个block,那么这个类A的实例对象a就拥有这个block,但是在block若又引用到了a,即a在block的引用计数增加1,a又属于block中,那么它俩就存在循环引用了。因此这个资源弄死就互相咬着,放不开。我们需要做的就是让它们无法形成循环引用。
一、如果项目没有开启ARC,使用__block声明重新对象。。。。资料太多了,而且现在基本都用ARC吧。所以暂时不记录这个了
二、如果项目开启了ARC,使用__weak声明对象。具体实例:
类A中嵌入带Block方法的类B,则类A中相关关键方法:
@interface A(){
B *bb;
}
@property(strong,nonatomic) NSString* strA;
@implementation A
-(void)AA{
__weak __typeof(self) weakSelf = self;
bb.block = ^(MBB *mbb){
//这里省略掉关于mbb的计算
weakSelf.strA = @"lalala";
};
}
//==========================然后呢,在B类的关键
typedef void (^block)(MBB *mbb); //定义一个block返回值void,参数为Mbb
@interface B : NSObject
-(void)method:(block)lala;
@end
@implementation B
-(void)method:(block)lala{
lala(参数);//然后就会自动运行到a的实例去了哦
}
找到一个写得更加具体的帖子,有兴趣的朋友可以去打望下:点此链接