// // ZYGCDViewController.h // Thread // // Created by wanglixing on 14/11/4. // Copyright © 2014年 zzz. All rights reserved. // #import <UIKit/UIKit.h> @interface ZYGCDViewController : UIViewController @end
// // ZYGCDViewController.m // Thread // // Created by wanglixing on 14/11/4. // Copyright © 2014年 zzz. All rights reserved. // #import "ZYGCDViewController.h" @interface ZYGCDViewController () @end @implementation ZYGCDViewController - (void)viewDidLoad { self.view.backgroundColor = [UIColor whiteColor]; } - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { //GCD 在实现多线程的时候有两个优点: //1.可以充分利用多核处理器的性能。 //2.使用起来简单方便,不需要管理线程的生命周期,可以使我们更关注于需要在线程中执行的任务。 //GCD 使用队列(queue)管理线程。队列一般分两种: //1.运行在主线程的队列,mainQueue。一次只能执行一个任务,遵循先进先出的原则(FIFO),串行队列。 //获得 mainQueue 队列。 dispatch_queue_t mainQueue = dispatch_get_main_queue(); //2.运行在分线程的队列,四个优先级不同的 globalQueue。并行队列,同时可以执行多个任务。globalQueue 管理了一组的分线程,实际运行的时候使用哪一个分线程,我们是不能控制的。 //#define DISPATCH_QUEUE_PRIORITY_HIGH 2 //#define DISPATCH_QUEUE_PRIORITY_DEFAULT 0 //#define DISPATCH_QUEUE_PRIORITY_LOW (-2) //#define DISPATCH_QUEUE_PRIORITY_BACKGROUND INT16_MIN //第一个参数是优先级,第二个参数无意义。 dispatch_queue_t globalQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); //只需要把任务提交到队列中,任务就会在对应的线程中执行了。 //同步,阻塞线程,等待任务执行完毕才继续执行后续代码。 //异步,同时执行。 //同步提交,如果在主线程使用,会导致线程死锁。 // dispatch_sync(<#dispatch_queue_t queue#>, <#^(void)block#>); // NSLog(@"========="); // // dispatch_sync(mainQueue, ^{ // NSLog(@"----------"); // }); // // NSLog(@"+++++++++++"); //异步提交,一般只使用这种方法。 dispatch_async(mainQueue, ^{ //block 的内容在主线程执行。 if ([NSThread isMainThread]) { NSLog(@"主线程"); }else { NSLog(@"分线程"); } }); dispatch_async(globalQueue, ^{ //block 的内容在分线程执行。 if ([NSThread isMainThread]) { NSLog(@"=====主线程"); }else { NSLog(@"=====分线程"); } }); //串行队列,先进先出,依次执行。 // dispatch_async(mainQueue, ^{ // NSLog(@"11111111111"); // NSLog(@"11111111111"); // NSLog(@"11111111111"); // NSLog(@"11111111111"); // NSLog(@"11111111111"); // }); // // dispatch_async(mainQueue, ^{ // NSLog(@"22222222222"); // NSLog(@"22222222222"); // NSLog(@"22222222222"); // NSLog(@"22222222222"); // NSLog(@"22222222222"); // }); // // dispatch_async(mainQueue, ^{ // NSLog(@"33333333333"); // NSLog(@"33333333333"); // NSLog(@"33333333333"); // NSLog(@"33333333333"); // NSLog(@"33333333333"); // }); // // dispatch_async(mainQueue, ^{ // NSLog(@"44444444444"); // NSLog(@"44444444444"); // NSLog(@"44444444444"); // NSLog(@"44444444444"); // NSLog(@"44444444444"); // }); //并行队列,多个任务同时执行。 // dispatch_async(globalQueue, ^{ // NSLog(@"11111111111"); // NSLog(@"11111111111"); // NSLog(@"11111111111"); // NSLog(@"11111111111"); // NSLog(@"11111111111"); // }); // // dispatch_async(globalQueue, ^{ // NSLog(@"22222222222"); // NSLog(@"22222222222"); // NSLog(@"22222222222"); // NSLog(@"22222222222"); // NSLog(@"22222222222"); // }); // // dispatch_async(globalQueue, ^{ // NSLog(@"33333333333"); // NSLog(@"33333333333"); // NSLog(@"33333333333"); // NSLog(@"33333333333"); // NSLog(@"33333333333"); // }); // // dispatch_async(globalQueue, ^{ // NSLog(@"44444444444"); // NSLog(@"44444444444"); // NSLog(@"44444444444"); // NSLog(@"44444444444"); // NSLog(@"44444444444"); // }); //可以自定义队列,但是一般用不上,系统提供给我们的两个已经够用了。 // dispatch_queue_create("com.www.zhiyou", nil); //系统的某些方法也会用到 mainQueue 和 globalQueue。 //通常这样使用 GCD。 dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //去分线程执行代码。 dispatch_async(dispatch_get_main_queue(), ^{ //切回主线程,刷新 UI。 }); }); //下载图片。 dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //下载图片。dataWithContentsOfURL 是同步请求。 NSData* data = [NSData dataWithContentsOfURL:[NSURL URLWithString:@"http://xxx/1.jpg"]]; UIImage* image = [UIImage imageWithData:data]; //切换回主线程。 dispatch_async(dispatch_get_main_queue(), ^{ UIImageView* imageView = [[UIImageView alloc] initWithImage:image]; [self.view addSubview:imageView]; [imageView release]; }); }); //等待某些任务执行完毕后,再去执行另外一个任务。 dispatch_group_t group = dispatch_group_create(); dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ // 下载图片1。 NSLog(@"11111111111"); NSLog(@"11111111111"); NSLog(@"11111111111"); NSLog(@"11111111111"); NSLog(@"11111111111"); }); dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //下载图片2。 NSLog(@"22222222222"); NSLog(@"22222222222"); NSLog(@"22222222222"); NSLog(@"22222222222"); NSLog(@"22222222222"); }); //等待 group 中的全部任务执行完毕,才会执行这里的任务。 dispatch_group_notify(group, dispatch_get_main_queue(), ^{ NSLog(@"33333333333"); NSLog(@"33333333333"); NSLog(@"33333333333"); NSLog(@"33333333333"); NSLog(@"33333333333"); }); } @end