与JavaScript
中的事件机制不同,iOS
里的事件广播机制是同步的,默认情况下,广播一个通知,会阻塞后面的代码:
-(void) click
{
NSNotificationCenter *center = [NSNotificationCenter defaultCenter];
[center postNotificationName:@"event_happend" object:self];
NSLog(@"HQ1111");
}
按下按钮后,发送一个广播,此前已经注册了2个此事件的侦听者
-(id) init
{
self = [super init];
if(self){
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(whenReceive:) name:@"event_happend" object:nil];
}
return self;
}
-(void) whenReceive:(NSNotification*) notification
{
NSLog(@"HQ2222");
}
-(id) init
{
self = [super init];
if(self){
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(whenReceive:) name:@"event_happend" object:nil];
}
return self;
}
-(void) whenReceive:(NSNotification*) notification
{
NSLog(@"HQ3333");
}
执行这段代码,首先会输出HQ2222,然后是HQ3333,最后才是HQ1111。调试发现,代码始终是跑在同一个线程中(广播事件的线程),广播事件之后的代码被阻塞,直到所有的侦听者都执行完响应
所以,由于NotificationCenter
的这个特性,如果希望广播的事件异步处理,则需要在侦听者的方法里开启新线程。应该把Notification
作为组件间解耦的方式,而不是利用它来实现异步处理。