博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GCD主队列死锁和全局队列
阅读量:4088 次
发布时间:2019-05-25

本文共 1309 字,大约阅读时间需要 4 分钟。

每一个应用程序只有一个主线程即只有一个主队列

在线程间通信中一定会使用,文章链接
主队列 : 在主线程
全局队列 : 在子线程

#pragma mark - 主队列 + 异步任务 == 正确的打开方式// 主队列使用的注意点 : 一定要将异步的任务添加到主队列- (void)GCDDemo{    // 1.获取主队列    dispatch_queue_t mainQueue = dispatch_get_main_queue();    // 2.把异步任务添加到主队列    dispatch_async(mainQueue, ^{        NSLog(@"%@",[NSThread currentThread]);    });    NSLog(@"正确的姿势");}

死锁:用过GCD的同学都知道

主线程中的执行时顺序执行的
那么下面的代码里,执行到
dispatch_sync(mainQueue, ^{
NSLog(@”%@”,[NSThread currentThread]);
的时候
就会在主队列中添加一个任务
我们暂且称它为A任务
因为,这些代码本身就书写在主线程中
那么我们将这段代码添加到了主线程中作为任务A
但是它本身也是一个任务,称它为B
想执行任务B中的NSLog,那么就必须执行任务A
而任务A,就是执行任务B
两个任务互相依赖
任务A包含任务B,执行顺序是A->B
完成A的前提是完成B
而执行任务B的前提是执行完了任务A
所以造成了一个互相等待的情况,谁也无法执行
所以无法解锁,造成死锁现象

#pragma mark - 主队列 + 同步任务 == 死锁- (void)GCDDemo{    // 1.获取主队列    dispatch_queue_t mainQueue = dispatch_get_main_queue();    // 2.把同步任务添加到主队列    dispatch_sync(mainQueue, ^{        NSLog(@"%@",[NSThread currentThread]);    });}

- (void)GCDDemo{    // 全局队列    /*     参数1 : 服务质量 / 优先级     参数2 : 苹果不知道这个参数的作用;给将来升级系统时预留的;     提示 : 开发中建议使用全局队列.执行的效果和自定义的并行队列是一样的     提示 : 当使用GCD的高级功能里面的barrier(阻塞)的时候,一定要用自定义的并行队列     */    dispatch_queue_t globalQueue = dispatch_get_global_queue(0, 0);    // 自定义并发队列    /*     参数1 : 队列的标识     参数2 : 决定了队列是并发的还是串行的     */    dispatch_queue_t queue = dispatch_queue_create("LONG", DISPATCH_QUEUE_CONCURRENT);}

转载地址:http://ffkii.baihongyu.com/

你可能感兴趣的文章
前端设计之特效表单
查看>>
前端设计之CSS布局:上中下三栏自适应高度CSS布局
查看>>
Java的时间操作玩法实例若干
查看>>
数字游戏
查看>>
JavaScript:时间日期格式验证大全
查看>>
pinyin4j:拼音与汉字的转换实例
查看>>
XML工具代码:SAX从String字符串XML内获取指定节点或属性的值
查看>>
时间日期:获取两个日期相差几天
查看>>
责任链模式 Chain of Responsibility
查看>>
高并发与大数据解决方案概述
查看>>
解决SimpleDateFormat线程安全问题NumberFormatException: multiple points
查看>>
MySQL数据库存储引擎简介
查看>>
处理Maven本地仓库.lastUpdated文件
查看>>
Windows操作系统安装MySQL解压版
查看>>
Java并发编程之Wait和Notify
查看>>
自定义git命令实现一步提交代码到仓库
查看>>
让谁搭车?
查看>>
Maven依赖版本号引发的血案
查看>>
什么是package-info.java
查看>>
Kafka | 请求是怎么被处理的?
查看>>