@interface ClassA : NSObject
@property (strong, nonatomic) dispatch_queue_t dispatchQ;
@property (strong, nonatomic) NSString *string;
@end
@implementation ClassA
- (id)init
{
self = [super init];
if (self) {
_dispatchQ = dispatch_queue_create("com.classa.q", NULL);
}
return self;
}
- (void)longRunningTaskWithCompletion:(void(^)(void))completion
{
dispatch_async(self.dispatchQ, ^{
for (int i = 0; i < 10000; i++) {
NSLog(@"%i", i);
}
dispatch_sync(dispatch_get_main_queue(), ^{
self.string = @"Class A Rocks!";
if(completion) {
completion();
}
});
});
}
@end
我认为这段代码会创建一个保留周期,因为-longRunningTaskWithCompletion:
中的块会捕获一个块中的self(设置字符串属性),并将该块添加到调度队列属性中。
答案 0 :(得分:11)
有一个保留周期,但它是暂时的。保留周期如下所示:
self
保留dispatchQ
dispatchQ
保留了阻止self
当块返回时,dispatchQ
将释放它。此时,保留周期被打破。该块已取消分配并释放self
。
答案 1 :(得分:4)
这不是保留周期。要有一个保留周期,self
需要在块保留self
时保留块。在发布的代码中,self
不会保留该块。因此没有保留周期。