/**
 核心概念
 任务:block里需要执行的操作
 队列:把任务添加进入队列中,按照先进先出的原则来执行任务
 
 串行队列:一个一个的执行
 并行队列:可以让多个任务并发(同时)执行(自动开启多个线程同时执行任务)并发功能只有在异步(dispatch_async)函数下才有效。
 
 同步任务:不会开辟新的线程,任务在当前的线程中执行,同时任务是立刻执行
 异步任务:会开辟新的线程(主队列不可以),任务在新开辟的线程执行(主队列在主线程中执行),不是立刻  执行任务
 
 同步任务串行队列:不会开启新的线程,当前的线程中顺序执行任务
 同步任务并行队列:不会开启新的线程,当前的线程中执行任务,立刻执行任务
 异步任务串行队列:会开辟一个新的线程,在新开辟的线程中执行任务,不是立刻执行
 异步任务并行队列:会开辟新的线程,在新开辟的线程中执行任务,任务的完成顺序是无序的,不是立刻执行
 
 主队列(特殊的串行队列):任务只会在主线程中调度,不会开辟新的线程(一般用于刷新UI)
 异步任务主队列:不会开辟新的线程,当前的线程中执行任务,不会立刻执行任务
 同步任务主队列:死锁
 
 全局队列(并行队列):全局队列供给应用程序共享,可以设置优先级
 
 开辟新的线程:由任务决定,同步任务不会开辟新的线程,异步任务会开辟新的线程(主队列不会开辟新的线程)
 开辟多少线程:由队列决定,串行队列只会开启一个线程,并行队列会开辟多个线程,具体多少个由任务的数量和GCD的底层来决定的

*/

//串行队列:一个一个执行
//同步操作:不开启新的线程
//执行结果:不开启新的线程,一个一个顺序执行

- (void)gcdTest1 {
   
    //label:队列名
    //attr:队列属性(串行,并发)
    //DISPATCH_QUEUE_SERIAL 串行
    //DISPATCH_QUEUE_CONCURRENT 并发
   
    //#define DISPATCH_QUEUE_SERIAL NULL
   
    dispatch_queue_t queue = dispatch_queue_create("com.bjsxt",DISPATCH_QUEUE_SERIAL);
   
    NSLog(@"开始");
    //同步操作
    //操作任务:block
    dispatch_sync(queue, ^{
        //打印当前线程
        NSLog(@"%@",[NSThread currentThread]);
    });
   
    NSLog(@"结束");
      
}

//串行队列:一个一个执行
//异步操作:会开启新的线程
//执行结果:开启一个新的线程,在新开辟的线程中执行任务,不是立刻执行

- (void)gcdTest2 {
   
    dispatch_queue_t queue = dispatch_queue_create("com.bjsxt", NULL);
   
   
    NSLog(@"开始");
   
    for (NSInteger i = 0 ; i < 10; i ++ ) {
       
        //异步请求
        dispatch_async(queue, ^{
           
            NSLog(@"%@,%@",[NSThread currentThread],@(i));
           
        });
    }
   
    NSLog(@"结束");
   
   
}

//并发队列:多个线程同时执行
//异步操作:会开启新的线程
//执行结果:会开辟新的线程,在新开辟的线程中执行任务,任务的完成顺序是无序的,不是立刻执行

- (void)gcdTest3 {
   
    //开启并发队列
    dispatch_queue_t queue = dispatch_queue_create("com.bjsxt", DISPATCH_QUEUE_CONCURRENT);
   
    NSLog(@"开始");
   
    for (NSInteger i = 0 ; i < 10; i ++ ) {
       
        //执行异步操作
        dispatch_async(queue, ^{
           
            NSLog(@"%@",[NSThread currentThread]);
        });
    }
   
    NSLog(@"结束");
}

//并发队列:多个线程同时执行
//同步操作:不会开启新的线程
//执行结果:不会开启新的线程,立即执行

- (void)gcdTest4 {
   
    dispatch_queue_t queue = dispatch_queue_create("com.bjsxt", DISPATCH_QUEUE_CONCURRENT);
   
    NSLog(@"开始");
   
    for (NSInteger i = 0 ; i < 10; i ++ ) {
       
        dispatch_sync(queue, ^{
            NSLog(@"%@,%@",[NSThread currentThread],@(i));
        });
    }
   
    NSLog(@"结束");
}

主队列的异步操作
- (void)gcdTest5 {
   
    // 主队列就是一种特殊的串行队列
    // 特点:专门负责在主线程上调度任务,不会再子线程中去调度任务,无论是同步或异步中调用任务都只会在主线程上面执行
   
    dispatch_queue_t queue = dispatch_get_main_queue();
   
    NSLog(@"开始");
   
    for (NSInteger i = 0; i < 10; i ++) {
        //主队列执行异步操作,异步操作有一个等待的过程
        dispatch_async(queue, ^{
            NSLog(@"%@",[NSThread currentThread]);
        });
    }
   
    NSLog(@"结束");
}

主队列的同步操作

- (void)gcdTest6 {
   
    dispatch_queue_t queue = dispatch_get_main_queue();
   
    NSLog(@"1");
   
    //在主队列里执行同步操作,产生死锁
   
    //原因:同步线程等待主线程结束,才会执行任务。主线程等待同步立即执行,才会执行下一个任务。
   
    dispatch_sync(queue, ^{
        NSLog(@"2");
    });
   
    NSLog(@"3");

}

- (void)gcdTest7
{
    //全局队列
    //identifier  队列优先级
    //flags  苹果预留的参数(没有用)
    //DISPATCH_QUEUE_PRIORITY_DEFAULT  一般使用默认优先级
   
    //    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
   
    //默认是并发队列,dispatch_get_global_queue用的多
   
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
   
    for (NSInteger i = 0; i < 10; i++) {
       
        //并发加异步
        dispatch_async(queue, ^{
           
            NSLog(@"%@",[NSThread currentThread]);
           
        });
       
    }

}

GCD进程间通信

//button的响应方法
- (IBAction)downLoadImage:(id)sender {
   
    NSLog(@"%@",[NSThread currentThread]);
   
    //获取全局队列
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
   
    //执行异步操作
    dispatch_async(queue, ^{
   
        NSLog(@"%@",[NSThread currentThread]);
       
        NSString * urlString = @"http://design.yesky.com/uploadImages/2009/335/20091201140951681.jpg";
       
        NSData * data = [NSData dataWithContentsOfURL:[NSURL URLWithString:urlString]];
       
        UIImage * image = [UIImage imageWithData:data];
       
        //返回主线程更新UI
        dispatch_async(dispatch_get_main_queue(), ^{
           
            NSLog(@"%@",[NSThread currentThread]);

self.imageView.image = image;

});
    });
   
}

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
   
    //同步操作用途
   
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
   
    dispatch_sync(queue, ^{
        NSLog(@"登录");
    });
   
    dispatch_async(queue, ^{
        NSLog(@"下载小说A");
    });
   
    dispatch_async(queue, ^{
        NSLog(@"下载小说B");
    });
   
}

GCD同步异步 串行并行大解析的更多相关文章

  1. GCD的同步异步串行并行、NSOperation和NSOperationQueue一级用dispatch_once实现单例

    转:http://www.tuicool.com/articles/NVVnMn (1)GCD实现的同步异步.串行并行. ——同步sync应用场景:用户登录,利用阻塞 ——串行异步应用场景:下载等耗时 ...

  2. 【iOS开发-91】GCD的同步异步串行并行、NSOperation和NSOperationQueue一级用dispatch_once实现单例

    (1)GCD实现的同步异步.串行并行. --同步sync应用场景:用户登录,利用堵塞 --串行异步应用场景:下载等耗时间的任务 /** * 由于是异步.所以开通了子线程.可是由于是串行队列,所以仅仅须 ...

  3. iOS多线程——同步异步串行并行

    串行并行异步同步的概念很容易让人混淆,关于这几个概念我在第一篇GCD中有解释,但是还不够清晰,所以这里重写一篇博客专门对这几个概念进行区分: 先说一下队列和任务: (1)队列分为串行和并行,任务的执行 ...

  4. IOS多线程知识总结/队列概念/GCD/串行/并行/同步/异步

    进程:正在进行中的程序被称为进程,负责程序运行的内存分配;每一个进程都有自己独立的虚拟内存空间: 线程:线程是进程中一个独立的执行路径(控制单元);一个进程中至少包含一条线程,即主线程. 队列:dis ...

  5. [深度思考]·为什么CNN是同步(并行)而RNN是异步(串行)的呢?

    为什么CNN是同步(并行)而RNN是异步(串行)的呢? 个人主页--> https://xiaosongshine.github.io/ 1.问题引出 CNN与RNN都是采用parameter ...

  6. 串行&并行&并发,同步&异步

    1. 串行&并行&并发 1.1 串行 这个非常好理解,字面意思,像串成一个串一样,顺序执行 上一个没执行完的话,后面的就必须无条件等待 一般情况就是一个线程里:任务一个接一个执行,类似 ...

  7. STM32学习笔记(五) USART异步串行口输入输出(轮询模式)

    学习是一个简单的过程,只要有善于发掘的眼睛,总能学到新知识,然而如何坚持不懈的学习却很困难,对我亦如此,生活中有太多的诱惑,最后只想说一句勿忘初心.闲话不多扯,本篇讲诉的是异步串行口的输入输出,串口在 ...

  8. iOS:GCD理解1(同步-异步、串行-并行)

    1.并行-异步(ST1与ST2抢占资源) 1-1).获取 并行(全局)队列 ,DISPATCH_QUEUE_PRIORITY_DEFAULT 为默认优先级. dispatch_queue_t queu ...

  9. iOS:GCD理解1(串行-并行、同步-异步)

    1.获取并行.创建串行 队列 1-1).获取 并行(全局) 队列 ,DISPATCH_QUEUE_PRIORITY_DEFAULT 为默认优先级. dispatch_queue_t global_qu ...

随机推荐

  1. 脚本引用中的defer和async的用法和区别

    之前的博客漫谈前端优化中的引用资源优化曾经提到过脚本引用异步设置defer.async,没有细说,这里展开一下,谈谈它们的作用和区别,先上张图来个针对没用过的小伙伴有个初始印象: 是的,就是在页面脚本 ...

  2. Redis使用总结(2):Python接口

    安装redis-py sudo pip2 install redis 牛刀小试 redis连接实例是线程安全的,可以直接将redis连接实例设置为一个全局变量直接使用.如果需要另一个Redis实例(o ...

  3. 浅谈Dictionary用法

    一.基础篇 1.Dictionary泛型类提供了从一组键到一组值的映射,即键和值的集合类. 2.Dictionary通过键来检索值的速度是非常快的,这是因为 Dictionary 类是作为一个哈希表来 ...

  4. 为IEnumerable扩展一个ForEach方法

    IEnumerable没有一个ForEach方法,我们可以使用C#写一个扩展方法: Source Code: using System; using System.Collections.Generi ...

  5. WPF学习之绘图和动画

    如今的软件市场,竞争已经进入白热化阶段,功能强.运算快.界面友好.Bug少.价格低都已经成为了必备条件.这还不算完,随着计算机的多媒体功能越来越强,软件的界面是否色彩亮丽.是否能通过动画.3D等效果是 ...

  6. 精品干货丨APP常用导航框架

    文章目的:在整体上把握移动端App的导航框架,理解每种导航所具有的优点.局限性和其所适用的范围. 文章用心:典型APP案例(源码:http://www.jinhusns.com/Products/Do ...

  7. spring笔记3 spring MVC的基础知识3

    4,spring MVC的视图 Controller得到模型数据之后,通过视图解析器生成视图,渲染发送给用户,用户就看到了结果. 视图:view接口,来个源码查看:它由视图解析器实例化,是无状态的,所 ...

  8. Social Media POC KT Session

    地址: 1. http://c0048925.itcs.hp.com:8080/datamining/report/brandfocus.html Social Media POC是针对Social ...

  9. Java--Semaphore控制并发线程数量

    package com; import java.util.concurrent.Semaphore; /** * Created by yangyu on 16/11/28. */ /** * Se ...

  10. CSS——4种定位

    若是没有指定定位方式,默认为静态定位. 1.静态定位(static) 静态定位会将所有元素正常流入页面. 2.绝对定位(absolute) 绝对定位将元素完全从页面流中取出,允许你为他制定一个绝对的位 ...