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等价