ios Block에서 흔히 볼 수 있는 오류 (3) - 병렬 프로그래밍의 Block 인용
실례지만 DemoObj의 대상은 정확하게 석방될 수 있습니까? 왜요?
//DemoObj.m
@interface DemoObj()
@property (nonatomic, strong) NSOperationQueue *queue;
@end
@implementation DemoObj
- (instancetype)init
{
self = [super init];
if (self) {
self.queue = [[NSOperationQueue alloc] init];
}
return self;
}
- (void)dealloc
{
NSLog(@"demoobj dealloc");
}
- (void)demoOp:(id)obj
{
NSLog(@"%@ %@", [NSThread currentThread], obj);
}
- (void)demoBlockOp
{
for (int i = 0; i < 10; ++i) {
[self.queue addOperationWithBlock:^{
[self demoOp:@(i)];
}];
}
}
//SMViewController.m
- (void)viewDidLoad
{
[super viewDidLoad];
DemoObj *obj = [[DemoObj alloc] init];
[obj demoBlockOp];
}
본인의 지난 블로그를 본 독자들은 DemoObj의 대상이 정확하게 풀리지 않는 것은 순환 인용이 생겼기 때문이라고 대답할 수 있습니다.
그러나 실제 상황은 DemoObj의 대상이 정확하게 방출될 수 있으니 독자들이 한번 실행해 보는 것도 괜찮다.
정확하게 방출될 수 있는 이유는 병렬 프로그래밍에서 Block의 관리와 라인의 생성과 소각은 대기열이 책임집니다!큐가 제거되면 큐의 모든 객체가 제거됩니다.
순환 인용은self에서 직접 블록을 강제로 인용해야만 나타난다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.