您的位置:首页 > 移动开发 > IOS开发

ios开发--GCD使用介绍:4-延迟执行操作

2016-03-30 19:36 567 查看

在开发过程中,我们有时会希望把一些操作封装起来延迟一段时间后再执行。iOS开发中,有两种常用的方法可以实现延迟执行,一种是使用GCD,另外一种是使用NSRunLoop类中提供的方法。


1、使用GCD实现延迟执行

在GCD中可以使用dispatch_after()函数,封装一段代码到block中,在设置的延迟时间(dispatch_time_t)之后执行。

void dispatch_after( dispatch_time_t when, dispatch_queue_t queue, dispatch_block_t block);

如下所示:在2.0秒后,输出一段日志。在该方法中,延迟执行的代码在主队列中执行,我们也可以修改执行的队列。

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

NSLog(@"延迟2.0秒后打印出来的日志!");

});

2、使用NSRunLoop类中的方法实现延迟执行

在NSRunLoop类中,也提供了有关延迟执行的方法。由于这些方法是对NSObject类的扩展,因此,所有的类都可以使用。

@interface NSObject (NSDelayedPerforming)

- (void)performSelector:(SEL)aSelector withObject:(nullable id)anArgument afterDelay:(NSTimeInterval)delay inModes:(NSArray *)modes;

- (void)performSelector:(SEL)aSelector withObject:(nullable id)anArgument afterDelay:(NSTimeInterval)delay;

@end

下面的代码中也实现了延迟2秒打印一段日志的操作。

- (void)viewDidLoad {

[super viewDidLoad];

//延迟2秒执行printLog

[self performSelector:@selector(printLog) withObject:nil afterDelay:2.0];

}

-(void) printLog{

NSLog(@"延迟2.0秒后打印出来的日志!");

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: