您好,登錄后才能下訂單哦!
不懂iOS如何實現簡單易用的GCD計時器??其實想解決這個問題也不難,下面讓小編帶著大家一起學習怎么去解決,希望大家閱讀完這篇文章后大所收獲。
在學習iOS過程中,想定大家對于定時器都不陌生,在日常開發中總會碰到需要計時器的功能,常見的定時器有NSTimer、GCD、CADisplayLink。網上也有很多的教程介紹三者的區別,主要講的是GCD這種方式使用以及封裝。
三者概括區別
優點 | 缺點 | |
---|---|---|
NSTimer | 使用簡單 | 受Runloop影響會導致計時不精準 |
CADisplayLink | 精度高      | CPU負載的時候會影響觸發事件,且觸發事件大于觸發間隔會導致掉幀現象。 |
GCD | 較精準 | 代碼較多,基本不受其他影響 |
總結:NSTimer和CADisplayLink易受影響,而GCD雖然代碼多,但是可控性非常強。
GCD
/** 獲取一個全局的線程來運行計時器*/ dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); /** 創建一個計時器*/ dispatch_source_t timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue); /** 設置計時器, 這里是每10毫秒執行一次*/ dispatch_source_set_timer(timer, dispatch_walltime(nil, 0), 10*NSEC_PER_MSEC, 0); /** 設置計時器的里操作事件*/ dispatch_source_set_event_handler(timer, ^{ //do you want.... });
開啟、繼續已暫停的定時器
dispatch_resume(timer);
暫停定時器
/** 掛起的時候注意,多次暫停的操作會導致線程鎖的現象,即多少次暫停, * 對應多少次的繼續操作,即dispatch_suspend和dispatch_resume * 是成對出現的,計時器才會繼續工作。 */ dispatch_suspend(timer);
結束定時器
dispatch_source_cancel(timer);
構思封裝
寫代碼之前構思好功能模塊以及會遇到的問題的解決方案、代碼邏輯,再來下手寫代碼,會有事半功倍的效果。
部分代碼
/** app進入后臺*/ - (void)appDidEnterBackground{ [self suspend]; NSDate *date = [[NSDate alloc] init]; NSDateFormatter *format = [[NSDateFormatter alloc] init]; format.dateFormat = @"yyyy-MM-dd HH:mm:ss:SSS"; self.appDidEnterBackgroundTime = [date timeIntervalSince1970]; } /** app進入前臺*/ - (void)appDidEnterForeground{ NSDate *date = [[NSDate alloc] init]; NSDateFormatter *format = [[NSDateFormatter alloc] init]; format.dateFormat = @"yyyy-MM-dd HH:mm:ss"; self.appDidEnterForegroundTime = [date timeIntervalSince1970]; [self reCalculateMinder]; } /** 不失精度加減乘除計算結果*/ - (NSDecimalNumber *)value: (NSTimeInterval)value byOpration: (OMDecimalOprationType)byOpration percision: (NSInteger)percision withValue: (NSTimeInterval)withValue{ NSDecimalNumber *number = [self numberValueWithString: value]; NSDecimalNumber *withNumber = [self numberValueWithString: withValue]; NSDecimalNumberHandler *handler = [NSDecimalNumberHandler decimalNumberHandlerWithRoundingMode: NSRoundPlain scale: percision raiseOnExactness: NO raiseOnOverflow: NO raiseOnUnderflow: NO raiseOnDivideByZero: YES]; switch (byOpration) { case OMDecimalOprationTypeAdd: return [number decimalNumberByAdding: withNumber withBehavior:handler]; break; case OMDecimalOprationTypeSubtract: return [number decimalNumberBySubtracting: withNumber withBehavior: handler]; break; case OMDecimalOprationTypeDivide: return [number decimalNumberByDividingBy: withNumber withBehavior: handler]; break; case OMDecimalOprationTypeMultiple: return [number decimalNumberByMultiplyingBy: withNumber withBehavior: handler]; break; default: break; return nil; }
@property (nonatomic, strong) OMTimer *timer;
self.timer = [[OMTimer alloc] init]; self.timer.timerInterval = 30; self.timer.precision = 100; self.timer.isAscend = NO; self.timer.progressBlock = ^(OMTime *progress) { NSLog(@"%@:%@:%@:%@", progress.hour, progress.minute, progress.second, progress.millisecond; };self.timer.completion = ^{ NSLog(@"complete done!"); };
Swift版本
最近喜歡上了OC,如有小伙伴需要Swift的版本的話可以留言或者私我,可以在寫個Swift版本,:stuck_out_tongue_winking_eye:。
感謝你能夠認真閱讀完這篇文章,希望小編分享iOS如何實現簡單易用的GCD計時器?內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。