IOS NSRunloop 的使用

利用NSRunLoop阻塞NSOperation线程
在使用NSOperationQueue简化多线程开发中介绍了多线程的开发,我这里主要介绍一下使用NSRunLoop阻塞线程。
主要使用在NStimer定时启用的任务或者异步获取数据的情况如socket获取网络数据,要阻塞线程,直到获取数据之后在释放线程。
下面是线程中没有使用NSRunLoop阻塞线程的代码和执行效果:
线程类:

#import <Foundation/Foundation.h>
@interface MyTask : NSOperation {    
}

@end
#import "MyTask.h"
@implementation MyTask
-(void)main    
{     
    NSLog(@"开始线程=%@",self);     
    [NSTimer timerWithTimeInterval:2 target:self selector:@selector(hiandeTime:) userInfo:nil repeats:NO];     
}     
-(void)hiandeTime:(id)sender     
{     
    NSLog(@"执行了NSTimer");     
}     
-(void)dealloc     
{     
    NSLog(@"delloc mytask=%@",self);     
    [super dealloc];     
}

@end

线程添加到队列中:

- (void)viewDidLoad    
{     
    [super viewDidLoad];     
    NSOperationQueue *queue=[[NSOperationQueue alloc] init];     
    MyTask *myTask=[[[MyTask alloc] init] autorelease];     
    [queue addOperation:myTask];     
    MyTask *myTask1=[[[MyTask alloc] init] autorelease];     
    [queue addOperation:myTask1];     
    MyTask *myTask2=[[[MyTask alloc] init] autorelease];     
    [queue addOperation:myTask2];     
    [queue release];     
}

执行结果是:
2011-07-25 09:44:45.393 OperationDemo[20676:1803] 开始线程=<MyTask: 0x4b4dea0>  
2011-07-25 09:44:45.393 OperationDemo[20676:5d03] 开始线程=<MyTask: 0x4b50db0>   
2011-07-25 09:44:45.396 OperationDemo[20676:1803] 开始线程=<MyTask: 0x4b51070>   
2011-07-25 09:44:45.404 OperationDemo[20676:6303] delloc mytask=<MyTask: 0x4b4dea0>   
2011-07-25 09:44:45.404 OperationDemo[20676:5d03] delloc mytask=<MyTask: 0x4b50db0>   
2011-07-25 09:44:45.405 OperationDemo[20676:6303] delloc mytask=<MyTask: 0x4b51070>

可以看到,根本没有执行NSTimer中的方法,线程就释放掉了,我们要执行
NSTimer中的方法,就要利用NSRunLoop阻塞线程。下面是修改后的代码:

-(void)main    
{     
    NSLog(@"开始线程=%@",self);     
    NSTimer *timer=[NSTimer timerWithTimeInterval:2 target:self selector:@selector(hiandeTime) userInfo:nil repeats:NO];     
    [timer fire];     
    while (!didDisconnect) {     
        [[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];     
    }     
}
执行结果如下:
2011-07-25 10:07:00.543 OperationDemo[21270:1803] 开始线程=<MyTask: 0x4d16380>    
2011-07-25 10:07:00.543 OperationDemo[21270:5d03] 开始线程=<MyTask: 0x4d17790>     
2011-07-25 10:07:00.550 OperationDemo[21270:6303] 开始线程=<MyTask: 0x4d17a50>     
2011-07-25 10:07:00.550 OperationDemo[21270:1803] 执行了NSTimer     
2011-07-25 10:07:00.551 OperationDemo[21270:5d03] 执行了NSTimer     
2011-07-25 10:07:00.552 OperationDemo[21270:6303] 执行了NSTimer     
2011-07-25 10:07:00.556 OperationDemo[21270:6503] delloc mytask=<MyTask: 0x4d16380>     
2011-07-25 10:07:00.557 OperationDemo[21270:6303] delloc mytask=<MyTask: 0x4d17790>     
2011-07-25 10:07:00.557 OperationDemo[21270:5d03] delloc mytask=<MyTask: 0x4d17a50>
我们可以使用NSRunLoop进行线程阻塞。

你可能感兴趣的:(NSRunLoop)