线程中

同步任务是串行队列,也就是按顺序执行。

同步任务:不会开辟新的线程,它是在当前线程执行的。

dispatch 调度   GCD里面的函数都是以dispatch开头的。

同步任务  步骤:

1.创建一个串行队列    参数:1.队列标签   2.队列属性   DISPATCH_QUEUE_SERIAL它是个宏,是个NULL

dispatch_queue_t queue = dispatch_queue_create("ZPqueue",DISPATCH_QUEUE_SERIAL);

2.同步执行任务  一般只要使用同步执行,串行队列对添加的同步任务,就会马上执行。

dispatch_sync(queue,^{NSLog(@"%@",[NSThread currentThread]);});

异步执行:肯定会开新线程,而且只会开一个线程,所有任务都会在这个新的线程里面执行。

异步任务 步骤:

dispatch_queue_t queue = dispatch_queue_create("ZPasyncQueue",DISPATCH_QUEUE_SERIAL);

2.同步执行任务  一般只要使用同步执行,串行队列对添加的同步任务,就会马上执行。

dispatch_async(queue,^{NSLog(@"%@",[NSThread currentThread]);});

并发队列:会开多个线程,并且它要开多少个线程是我们无法控制的。

dispatch_queue_t queue = dispatch_queue_create("ZPasyncQueue",DISPATCH_QUEUE_CONCURRENT);

2.同步执行任务  一般只要使用同步执行,串行队列对添加的同步任务,就会马上执行。

dispatch_async(queue,^{NSLog(@"%@",[NSThread currentThread]);});

总结:

核心概念:

任务:block

队列:把任务放到队列里面,队列遵循先进先出原则。

串行队列:按顺序执行,当前任务执行完毕才会执行下一个目标任务。

并发队列:同时执行多个任务(可以同时去除多个任务,只要有线程)。

串行队列同步执行:不开线程,在原来的线程里面一个一个的按顺序执行。

串行队列异步执行:开一条线程,在新的线程里面按顺序执行。

并发队列异步执行:开多个线程,并发执行(不一定是一个一个的执行,可能会是多个一起执行)。

并发队列同步执行:不开线程,在原来的线程里面一个一个按顺序执行。

阶段性总结:

1.开不开线程,由执行任务方法决定,同步不开线程,异步肯定开线程。

2.开多少线程,由队列决定,串行最多开一个线程,并发可以开多个线程。具体开多少个由GCD底层决定,程序员不能控制。

**主队列**

// 主队列  :专门负责在主线程上调度任务,不会再子线程调度任务,在主队列不允许开新线程

// 主队列:不允许开新线程

// 异步执行:会开新线程,在新线程执行。

// 结果:不卡线程,只能在主线程上面运行,顺序执行。

步骤:

获得主队列   --- 程序一旦启动至少有一个主线程--->一开始就会创建主队列

-(void)test1{

   // 1.获得主队列 

dispatch_queue_t queue = dispatch_get_main_queue();

  // 2.异步执行任务

  for(int i = 0; i < 10; i++)

  {

   NSLog(@"调度前-----");

   // 异步:把任务放到主队列里,但是不需要马上执行。它跟for循环没有关系,test1执行完毕之后他会全部执行完成。

  dispatch_async(queue,^{

    NSLog(@"%@ %d",[NSThread currnetThread],i);

    });

   }

    NSLog(@"完成---");  // 在这里执行完毕之后会执行主队列的东西。

}

注意:异步执行:异步任务不需要马上执行,只是先把任务放到主队列,等线程有空再去执行,就是等到test1执行结束了,主线程有空闲了就去执行

**同步任务**

-(void)test2{

   // 1.获得主队列 

dispatch_queue_t queue = dispatch_get_main_queue();

  // 2.异步执行任务

  for(int i = 0; i < 10; i++)

  {

   NSLog(@"调度前-----");

   // 异步:把任务放到主队列里,但是不需要马上执行。它跟for循环没有关系,test1执行完毕之后他会全部执行完成。

  dispatch_sync(queue,^{

    NSLog(@"%@ %d",[NSThread currnetThread],i);

    });

   }

    NSLog(@"完成---");  // 在这里执行完毕之后会执行主队列的东西。

}

注意:这个任务是执行不下去的,因为同步任务需要马上执行,但是主线程上面正在执行test2,所以需要等待test2执行完毕之后才能执行同步任务,但是test2在等待这个同步任务执行结束,这样就造成主线程阻塞,产生死锁。谁也没有办法往下执行。

并发队列:

-(void)test3

{

  // 例子:有一个小说网站,必须登陆才能下载小说

  // 分析:上面是有三个任务---1,用户登录 2,下载小说a  3,下载小说b  

// 所以这个小说网站是通过同步执行。

  dispatch_queue_t queue = dispatch_queue_create("cz",DISPATCH_QUEUE_CONCURRENT);

  dispatch_sync(queue,^{

    NSLog(@"用户登录%@",[NSThread currentThread]);

  });

}

**全局队列**

/**

全局队列跟并发队列的区别

1.全局队列:没有名称,并发队列有名称

2.全局队列,是供所有的应用程序共享

3.再mrc开发,并发队列创建完成,需要释放;全局队列不需要管理。

*/

-(void)test4

{

  // 获取全局队列

  // DISPATCH_QUEUE_PRIORITY_HIGH 2 高级优先级  IOS7.0

  // DISPATCH_QUEUE_PRIORITY_DEFAULT 0  默认优先级 IOS7.0

  // DISPATCH_QUEUE_PRIORITY_LOW (-2) 低优先级 IOS7.0

  // DISPATCH_QUEUE_PRIORITY_BACKGROUND INT16_MIN 后台优先级  IOS7.0

  // IOS8.0 QOS_CLASS_DEFAULT 0 ;

// 参数:1.优先级 (一般写 0  可以适配ios7盒ios8)2.预留参数(也是直接写0)

  dispatch_queue_t  queue = dispatch_get_global_queue  queue(0,0);

  // 添加异步任务

dispatch_async(queue,^{

    NSLog(@"用户登录%@",[NSThread currentThread]);

  });

}

******************************************************************

**      *  全局并行队列    * 手动创建串行队列   *  主队列      *

******************************************************************

**同步并行  *   没有开启新线程    * 没有开启新线程    *  死锁         *

      *     串行执行任务       * 串行执行任务                *

**异步    *   有开启新线程     * 有开启新线程     *  没有开启新线程  *

      *     并行执行任务     * 串行执行任务     *  串行执行任务     *

******************************************************************

队列的选择:

串行队列异步执行

--开一条线程,顺序执行。

--效率不高,执行的比较慢,资源占用小->省电

使用场合:

一般网络连接(3g 4g)对性能要求不会很高

并发队列异步执行

--开启多条线程,并发执行

--效率高,执行快。资源占用大->费电。

使用场合:

-网络wifi   或者需要很快响应,要求用户体验非常流畅。

-对任务执行顺序没有要求

同步任务:一般只会在并发队列,需要阻塞后续任务,必须等待同步任务执行完毕,再去执行其他任务。“依赖”关系。

从子线程回到主线程

dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0),^{

  // 执行耗时的异步操作。。。。

  dispatch_async(dispatch_get_main_queue(),^{

   // 回到主线程

  });

});

同步sync 异步async的更多相关文章

  1. 同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式

    1. 概念理解        在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式:   同步/异步主要针对C端: 同步:    ...

  2. 同步与异步 & 阻塞与非阻塞

    在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 一.同步 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用 ...

  3. socket阻塞与非阻塞,同步与异步、I/O模型,select与poll、epoll比较

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步/异步主要针对C端: 同步:      所谓同步,就 ...

  4. socket阻塞与非阻塞,同步与异步

    socket阻塞与非阻塞,同步与异步 作者:huangguisu 转自:http://blog.csdn.net/hguisu/article/details/7453390 1. 概念理解 在进行网 ...

  5. Python番外之 阻塞非阻塞,同步与异步,i/o模型

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步/异步主要针对C端: 同步:      所谓同步,就 ...

  6. 聊聊阻塞与非阻塞、同步与异步、I/O模型

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步/异步主要针对C端:  同步: 所谓同步,就是在c端 ...

  7. socket阻塞与非阻塞,同步与异步、I/O模型

    socket阻塞与非阻塞,同步与异步 1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式:同步:      所 ...

  8. 阻塞与非阻塞、同步与异步、I/O模型

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步/异步主要针对C端:  同步: 所谓同步,就是在c端 ...

  9. PHP-Socket-阻塞与非阻塞,同步与异步概念的理解

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式:同步:      所谓同步,就是在发出一个功能调用时,在没 ...

随机推荐

  1. easyui webapi

    今天算是踩雷了.... 先说一下,由于项目需要,我目前开发PO模块, 由于需要提供手机端,所以我在mvc项目中创建了  webapi.提供手机端调用. 然后我就考虑,easyui也使用webapi来提 ...

  2. File类总结

    1.File类是描述文件或文件夹的.File类可以用来操作文件或文件夹本身.但它不能操作文件中的数据. File( String name  )  把一个字符串封装成File对象.这个字符串可以是文件 ...

  3. LOJ #6270. 数据结构板子题 (离线+树状数组)

    题意 有 \(n\) 个区间,第 \(i\) 个区间是 \([l_i,r_i]\) ,它的长度是 \(r_i-l_i\) . 有 \(q\) 个询问,每个询问给定 \(L,R,K\) ,询问被 \([ ...

  4. pandas 从入门到遗忘

    读取大文件(内存有限): import pandas as pd reader = pd.read_csv("tap_fun_test.csv", sep=',', iterato ...

  5. cdn模式下vue的基本用法

    我们知道jq是简化了dom操作,而react和vue则是通过使用虚拟dom的方式,不需要频繁的更改ui界面,而是通过更改数据的方式来更新界面. 我们知道些jq插件时会在IFFE中传入jQuery,jQ ...

  6. php中的session过期思考一二

    看了php开发组成员鸟哥的一篇关于php设置session过期(http://www.laruence.com/2012/01/10/2469.html)的文章 他也说了一般人的回答的几个答案, 回答 ...

  7. 在Kubernetes集群中安装Helm及证书认证

    安装Kubernetes 测试环境使用kubeadm安装kubernetes v1.6.3版本, 安装过程略过. 为Helm创建客户端认证 客户端认证是为了能够使用helm命令行调用Helm的服务端T ...

  8. C# BindingSource

    1.引言 BindingSource组件是数据源和控件间的一座桥,同时提供了大量的API和Event供我们使用.使用这些API我们可以将Code与各种具体类型数据源进行解耦:使用这些Event我们可以 ...

  9. frp源码剖析-frp中的log模块

    前言&引入 一个好的log模块可以帮助我们排错,分析,统计 一般来说log中需要有时间.栈信息(比如说文件名行号等),这些东西一般某些底层log模块已经帮我们做好了.但在业务中还有很多我们需要 ...

  10. Hadoop生态圈-Oozie实战之调度shell脚本

    Hadoop生态圈-Oozie实战之调度shell脚本 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客展示案例:使用Oozie调度Shell脚本. 1>.解压官方案例 ...