iOS延遲執(zhí)行方法詳解
近日學習了延遲執(zhí)行的幾種方法,分享一下。
1.performSelector(NSObject)方法
2.NSTimer方法
3.GCD方法
4.sleep(NSThread)方法
延遲執(zhí)行代碼:
- (void)delayDo : (id)sender { NSLog(@"do:%@",sender); }
1.performSelector(NSObject)方法
這是iOS中常用的一種延遲執(zhí)行方法.
特點:這個方法必須要在主線程中使用.可以傳遞參數.可以取消操作,不能暫停.
//不帶參數 [self performSelector:@selector(delayDo:) withObject:nil afterDelay:1.0f]; //帶參數 [self performSelector:@selector(delayDo:) withObject:@"abc" afterDelay:1.0f];
取消操作分為2種:
(1)取消所有延遲執(zhí)行操作
[NSObject cancelPreviousPerformRequestsWithTarget:self];
(2)取消指定的延遲執(zhí)行操作
當你取消指定的延遲操作時,操作的唯一標示是傳遞的參數,只有傳遞了正確的參數才能取消操
//取消不傳參的方法 [NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(delayDo:) object:nil]; //取消傳參的方法 [NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(delayDo:) object:@"abc"];
2.NSTimer方法
采用計時器的延遲方法
特點:這個方法必須要在主線程中使用.可以傳遞參數.可以取消操作,可以暫停,可以立即執(zhí)行延遲操作
因為這個方法可以暫停,這里設置了一個變量isRun來判斷是否在運行.
//計時器對象 NSTimer * timer; //作為計時器判斷狀態(tài)的變量 BOOL isRun;
開始計時,repeats:NO.只執(zhí)行一次. YES,循環(huán)重復執(zhí)行.
timer = [NSTimer scheduledTimerWithTimeInterval:1.0f target:self selector:@selector(delayDo:) userInfo:@"abc" repeats:YES];
暫停操作:
if (isRun) { #warning 此方法是暫停的功能 其實是把時間拉遠了 isRun = NO; [timer setFireDate:[NSDate distantFuture]]; } else if (!isRun) { #warning 恢復計時器 isRun = YES; [timer setFireDate:[NSDate date]]; }
不等待計時器,立即執(zhí)行延遲操作
[timer fire];
銷毀/徹底取消計時器
#waring 此方法策底取消了Timer 不是暫停
[timer invalidate];
這里要說明一下,并不是只有invalidate方法才能銷毀計時器,當repeats屬性設為NO,計時器運行以后將會自動銷毀.
那么參數呢? NSTimer的參數是userInfo,所以要使用userInfo方法才能提取到正確的參數
NSlog(@"sender:%@",[sender userInfo]);
3.GCD方法
特點:這個方法不限制線程,不容易取消操作.
為什么不能取消操作?代碼交給了GCD自動進行處理,開發(fā)者不容易操作.
//在主線程延遲執(zhí)行 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ [self delayDo:@"GCD"]; }); //在子線程延遲執(zhí)行 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ [self delayDo:@"Global-GCD"]; });
改變 (5 * NSEC_PER_SEC) 的數字就可改變延遲時間,單位是秒.
默認是在主線程,改變dispatch_get_main_queue() ------->dispath_get_global_queue() 就可讓代碼在子線程執(zhí)行.
4.Sleep(NSThread)方法
特點:卡主當前線程來實現延遲操作,使用需謹慎. 有些時候,用起來還是很方便的.
[NSThread sleepForTimeInterval:3];
最好不要在主線程中使用,否則會卡住界面.
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
UIMenuController在Cell內部無法顯示的解決辦法(iOS9.2)
這篇文章主要為大家詳細介紹了UIMenuController在Cell內部無法顯示的解決辦法,感興趣的小伙伴們可以參考一下2016-08-08簡介iOS開發(fā)中應用SQLite的模糊查詢和常用函數
這篇文章主要介紹了iOS開發(fā)中應用SQLite的模糊查詢和常用函數,SQLite是一個可作嵌入式的數據庫非常適合小型應用使用,需要的朋友可以參考下2015-12-12IOS開發(fā)教程之put上傳文件的服務器的配置及實例分享
IOS開發(fā)給人一種高大上的趕腳,弄的好像你不會IOS就不是個合格的程序員一樣,好吧,既然是大趨勢,那我們就來學習下吧,今天來看看put上傳文件的服務器配置及案例2014-06-06