1.最直接的方法performSelector:withObject:afterDelay:
这种方法的缺点:每次要为延时写一个方法
2.使用类别,用BOLCK执行
[代码]c#/cpp/oc代码:
01 | @implementation NSObject (PerformBlockAfterDelay) |
03 | - ( void )performBlock:( void (^)( void ))block |
04 | afterDelay:(NSTimeInterval)delay |
06 | block = [[block copy] autorelease]; |
07 | [self performSelector:@selector(fireBlockAfterDelay:) |
12 | - ( void )fireBlockAfterDelay:( void (^)( void ))block { |
3.使用GCD
[代码]c#/cpp/oc代码:
1 | void RunBlockAfterDelay(NSTimeInterval delay, void (^block)( void )) |
3 | dispatch_after(dispatch_time(DISPATCH_TIME_NOW, NSEC_PER_SEC*delay), |
4 | dispatch_get_current_queue(), block); |
4.可能是不太好的方法,用animation的completion参数
[代码]c#/cpp/oc代码:
1 | [UIView animateWithDuration:0.0 delay:5.0 options:UIViewAnimationOptionAllowUserInteraction animations:^{ |
2 | } completion:^(BOOL finished) { |
5.使用NSOperationQueue,在应用程序的下一个主循环执行:
[代码]c#/cpp/oc代码:
1 | [[NSOperationQueue mainQueue] addOperationWithBlock:aBlock]; |
这个和调用performSelector: with afterDelay of 0.0f等价