//一、建立主線程(串行) dispatch_async(dispatch_get_main_queue(), ^{ //刷新界面代碼 }); //二、建立異步線程(並行) dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //比較耗時的代碼放這裏 }); //三、gcd延遲 double delayInSeconds = 1.0; dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC); dispatch_after(popTime, dispatch_get_main_queue(), ^(void){ //延遲代碼 }); //四、gcd只執行一次 static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ //只執行一次代碼 }); //五、有三個任務,須要異步併發執行前兩個任務,前兩個任務執行完成後再執行第三個任務。 dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //建立組 dispatch_group_t group=dispatch_group_create(); // 關聯一個任務到group dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //任務一 NSLog(@"******執行任務一******"); }); // 關聯一個任務到group dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //任務二 NSLog(@"******執行任務二******"); }); // 等待組中的任務執行完畢,回到主線程執行block回調 dispatch_group_notify(group, dispatch_get_main_queue(), ^{ //任務三 NSLog(@"******等待組中的任務執行完畢,回到主線程執行block回調,執行任務三******"); }); }); //六、dispatch_barrier_async的使用,dispatch_barrier_async是在前面的任務執行結束後它才執行,並且它後面的任務等它執行完成以後纔會執行 dispatch_queue_t queue = dispatch_queue_create("create_asy_queue", DISPATCH_QUEUE_CONCURRENT); dispatch_async(queue, ^{ NSLog(@"dispatch_async1"); }); dispatch_async(queue, ^{ NSLog(@"dispatch_async2"); }); dispatch_barrier_async(queue, ^{ NSLog(@"dispatch_barrier_async"); dispatch_async(dispatch_get_main_queue(), ^{ NSLog(@"刷新界面"); }); }); dispatch_async(queue, ^{ [NSThread sleepForTimeInterval:1]; NSLog(@"dispatch_async3"); }); /*七、GCD的另外一個用處是可讓程序在後臺較長久的運行。 在沒有使用GCD時,當app被按home鍵退出後,app僅有最多5秒鐘的時候作一些保存或清理資源的工做。可是在使用GCD後,app最多有10分鐘的時間在後臺長久運行。這個時間能夠用來作清理本地緩存,發送統計數據等工做。 讓程序在後臺長久運行的示例代碼以下: */ // AppDelegate.h文件 @property (assign, nonatomic) UIBackgroundTaskIdentifier backgroundUpdateTask; // AppDelegate.m文件 - (void)applicationDidEnterBackground:(UIApplication *)application { [self beingBackgroundUpdateTask]; // 在這裏加上你須要長久運行的代碼 [self endBackgroundUpdateTask]; } - (void)beingBackgroundUpdateTask { self.backgroundUpdateTask = [[UIApplication sharedApplication] beginBackgroundTaskWithExpirationHandler:^{ [self endBackgroundUpdateTask]; }]; } - (void)endBackgroundUpdateTask { [[UIApplication sharedApplication] endBackgroundTask: self.backgroundUpdateTask]; self.backgroundUpdateTask = UIBackgroundTaskInvalid; }