Czy @synchronized nie używa „blokady” i „odblokowania” do osiągnięcia wzajemnego wykluczenia? Jak to się wtedy blokuje / odblokowuje?
Wyjście następującego programu to tylko „Hello World”.
@interface MyLock: NSLock<NSLocking>
@end
@implementation MyLock
- (id)init {
return [super init];
}
- (void)lock {
NSLog(@"before lock");
[super lock];
NSLog(@"after lock");
}
- (void)unlock {
NSLog(@"before unlock");
[super unlock];
NSLog(@"after unlock");
}
@end
int main (int argc, const char * argv[]) {
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
MyLock *lock = [[MyLock new] autorelease];
@synchronized(lock) {
NSLog(@"Hello World");
}
[pool drain];
}
lock
Obiekt jest tworzony na każde wezwanie, więc nigdy nie będzie to przypadek, gdzie jeden @synchronized
zamki blokują inny. A to oznacza, że nie ma wzajemnego wykluczenia.) Oczywiście powyższy przykład wykonuje operację main
, więc i tak nie ma co wykluczyć, ale nie należy ślepo kopiować tego kodu w innym miejscu.