iOS多线程 - GCD介绍
来源:互联网 发布:摩卡软件招聘 编辑:程序博客网 时间:2024/05/22 05:06
iOS多线程 - GCD介绍
GCD是苹果为了多核并行运算,而提出的一套解决方案。
能够自动的管理线程的生命周期,比如创建线程、任务调度、销毁线程等,都不用开发者管理,
我们只需要告诉GCD干什么就行了。
#pragma mark - GCD- (void)clickGCD{ NSLog(@"执行GCD"); dispatch_async(dispatch_get_global_queue(0, 0), ^{ // 执行耗时任务 NSLog(@"执行耗时任务"); [NSThread sleepForTimeInterval:3]; //模拟耗时 // 回到主线程 dispatch_async(dispatch_get_main_queue(), ^{ // 这里回到主线程了 NSLog(@"回到主线程里,刷新UI"); }); });}
从log可以看出:主线程id17279600
,执行耗时任务在子线程17279679
,最后又回到主线程17279600
里刷新UI。
dispatch_get_global_queue
上面范例我们用到了dispatch_get_global_queue
,这是一个全局并发的queue。
我们来验证一下:
dispatch_async(dispatch_get_global_queue(0, 0), ^{ NSLog(@"star任务1"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务1"); }); dispatch_async(dispatch_get_global_queue(0, 0), ^{ NSLog(@"star任务2"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务2"); }); dispatch_async(dispatch_get_global_queue(0, 0), ^{ NSLog(@"star任务3"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务3"); });
查看控制台打印的结果:3个任务,在3个线程(线程id区分);依次开始,依次结束。这就说明了dispatch_get_global_queue
是一个全局的并发的queue。
dispatch_get_global_queue参数-设置优先级
有2个参数
dispatch_get_global_queue(long identifier, unsigned long flags);
第一个参数是来设置优先级的,第二个参数现在几乎不用了。
定义了4种优先级别:
#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_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_LOW, 0), ^{ NSLog(@"star任务1"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务1"); }); dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{ NSLog(@"star任务2"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务2"); }); dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ NSLog(@"star任务3"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务3"); });
用串行的queue保证执行顺序
// 创建queue dispatch_queue_t queue = dispatch_queue_create("com.test.gcd", NULL); // 用这个queue开始线程 dispatch_async(queue, ^{ NSLog(@"star任务1"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务1"); }); dispatch_async(queue, ^{ NSLog(@"star任务2"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务2"); }); dispatch_async(queue, ^{ NSLog(@"star任务3"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务3"); });
任务一个执行完毕,再执行另一个,属于串行。通过线程id,我们发现3个任务其实是一个线程来完成的。
创建queue也可以并行
dispatch_queue_create
第二个参数
// 创建queue dispatch_queue_t queue = dispatch_queue_create("com.test.gcd", DISPATCH_QUEUE_CONCURRENT); // 用这个queue开始线程 dispatch_async(queue, ^{ NSLog(@"star任务1"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务1"); }); dispatch_async(queue, ^{ NSLog(@"star任务2"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务2"); }); dispatch_async(queue, ^{ NSLog(@"star任务3"); [NSThread sleepForTimeInterval:2]; NSLog(@"end任务3"); });
3个线程并发执行。
0 0
- IOS GCD多线程介绍
- ios多线程 -- GCD介绍
- iOS多线程 - GCD介绍
- iOS开发多线程-GCD介绍
- iOS多线程(GCD重点介绍)
- iOS开发多线程篇—GCD介绍
- iOS多线程编程之GCD介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程篇—GCD介绍
- 关于ios多线程GCD的简单介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程—05GCD介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程篇—GCD介绍
- iOS开发多线程篇—GCD介绍
- freeswitch mod_callcenter配置
- 小白学react (初次使用)
- 【Class】Java中类、实例与Class对象
- Android运行时权限
- maven聚合与继承<一>
- iOS多线程 - GCD介绍
- Linux设备驱动二 (1)内核传参
- storm kafka一些文章
- sql语句里有中文字符,JDBC查询不出来结果
- qt4.7 组件重绘文字
- 批处理替换xml文件指定内容
- Win32——_beginthread()、CreateThread()、_beginthreadex()
- HTML表单学习4——输入属性
- 在oracle中varchar和varchar2有什么区别?