初始化一個NSThread對象以后,在線程回調(diào)方法里面進行操作,調(diào)起Runloop保活
self.taskThread = [[NSThread alloc] initWithTarget:self selector:@selector(doThreadMethod) object:nil];
如果runloop在運行,是只能看到任務(wù)開始的打印
- (void)doThreadMethod
{
NSLog(@"線程一任務(wù)開始: %@", [NSThread currentThread]);
// 執(zhí)行對應(yīng)的?;罘椒? [self threadKeep];
[[NSRunLoop currentRunLoop] run];
NSLog(@"線程一任務(wù)結(jié)束: %@", [NSThread currentThread]);
}
方法一: 添加Source1
AFNetwork用的這種方式
- (void)keepMethod01
{
[[NSRunLoop currentRunLoop] addPort:[NSPort port] forMode:NSDefaultRunLoopMode];
}
方法二: 添加Source0
- (void)keepMethod02
{
[self performSelector:@selector(method02Perform) onThread:[NSThread currentThread] withObject:nil waitUntilDone:NO];
}
- (void)method02Perform
{
NSLog(@"%s", __func__);
}
方法三: 添加Timer
- (void)keepMethod03
{
[NSTimer scheduledTimerWithTimeInterval:10 repeats:NO block:^(NSTimer * _Nonnull timer) {
NSLog(@"%s", __func__);
}];
}
其中方法二和方法三,按道理是已經(jīng)執(zhí)行完對應(yīng)的方法了,Runloop里面已經(jīng)沒有了對應(yīng)的Timer或者Source,但是測試發(fā)現(xiàn)這兩種方法是可行的,可能與Runloop進入時機是只在entry前判斷有關(guān)。