使用runloop阻塞线程的正确写法

使用runloop阻塞线程的正确写法

http://marshal.easymorse.com/archives/4700

runloop能够阻塞线程,等待其余线程执行后再执行。
好比:
@implementation ViewController{
    BOOL end;
}

– (void)viewDidLoad
{
    [super viewDidLoad]; 
    NSLog(@”start new thread …”);
    [NSThread detachNewThreadSelector:@selector(runOnNewThread) toTarget:self withObject:nil];    
    while (!end) {
        NSLog(@”runloop…”);
        [[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
        NSLog(@”runloop end.”);
    }
    NSLog(@”ok.”);
}
-(void)runOnNewThread{
     NSLog(@”run for new thread …”);
    sleep(1);
    end=YES;
    NSLog(@”end.”);
}
可是这样作,运行时会发现,while循环后执行的语句会在很长时间后才被执行。
那是否是能够这样:
[[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate: [NSDate dateWithTimeIntervalSinceNow:0.1]];
缩短runloop的休眠时间,看起来解决了上面出现的问题。
不过这样也又问题,runloop对象被常常性的唤醒,这违背了runloop的设计初衷。runloop的做用就是要减小cpu作无谓的空转,cpu可在空闲的时候休眠,以节约电量。
那么怎么作呢?正确的写法是:
-(void)runOnNewThread{
     NSLog(@”run for new thread …”);
    sleep(1);
     [self performSelectorOnMainThread:@selector(setEnd) withObject:nil waitUntilDone:NO];
    NSLog(@”end.”);
}
-(void)setEnd{
    end=YES;
}
见黑体斜体字部分,要将直接设置变量,改成向主线程发送消息,执行方法。问题获得解决。
这里要说一下,形成while循环后语句延缓执行的缘由是,runloop未被唤醒。由于,改变变量的值,runloop对象根本不知道。延缓的时长老是不定的,这是由于,有其余事件在某个时点唤醒了主线程,这才结束了while循环。那么,向主线程发送消息,将唤醒runloop,所以问题就解决了。
相关文章
相关标签/搜索