GCD基础知识集合

GCD概念简单理解

GCD是基于C的Api。不需要自己管理线程生死。只需要创建队列,把任务放进队列里面就可以了。看上去很简单,其实也是有一段心酸路。
GCD有两个核心概念。一个是任务,一个是队列。

同步函数:在当前线程中执行,不开启新的线程
dispatch_sync(dispatch_queue_t queue, dispatch_block_tblock);

异步函数:具备开启线程的能力。
dispatch_async(dispatch_queue_t queue, dispatch_block_tblock);

队列

并发队列
自动开启多个线程,并且可以让多个任务同时执行。
仅仅在异步函数(dispatch_async)下有效。

串行队列
让线程一个接着一个的执行。一条线程执行完后再执行下一条线程。

并发队列

并发队列不需要手动创建。以下是创建代码。

dispatch_queue_tdispatch_get_global_queue(
dispatch_queue_priority_tpriority,// 队列的优先级
unsignedlongflags);// 此参数暂时无用,用0即可
dispatch_queue_tqueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);//获得全局并发队列

全局并发队列的优先级
#defineDISPATCH_QUEUE_PRIORITY_HIGH 2 // 高
#defineDISPATCH_QUEUE_PRIORITY_DEFAULT 0 // 默认(中)
#defineDISPATCH_QUEUE_PRIORITY_LOW (-2)// 低
#defineDISPATCH_QUEUE_PRIORITY_BACKGROUND INT16_MIN // 后台
串行队列
使用dispatch_queue_create函数创建串行队列
dispatch_queue_t
dispatch_queue_create(constchar*label, //队列名称
dispatch_queue_attr_tattr);//队列属性,一般用NULL即可
dispatch_queue_tqueue = dispatch_queue_create("isQueue", NULL);//创建
dispatch_release(queue);//非ARC时候需要释放手动创建的队列

使用主队列(跟主线程相关联的队列)
主队列是GCD自带的一种特殊的串行队列
放在主队列中的任务,都会放到主线程中执行
使用dispatch_get_main_queue()获得主队列
dispatch_queue_tqueue = dispatch_get_main_queue();

使用dispatch_sync同步函数时候,在主线程中往主队列添加任务会造成死锁

队列与任务的结合
函数 全局并发队列 手动创建串行队列 主队列
同步 (sync) 没有开启新线程 串行执行任务 没有开启新线程 串行执行任务 没有开启新线程 串行执行任务
异步 (async) 有开启新线程 并发执行任务 有开启新线程 串行执行任务 没有开启新线程 串行执行任务
线程间的通讯

更新UI,数据等都是要回到主线程的。不能在子线程。

//获取全局队列
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    dispatch_async(queue, ^{

        NSLog(@"-子线程-- 开始下载图片--%@",[NSThread currentThread]);

        //下载数据是耗时操作放到子线程
        UIImage *image = [UIImage imageWithData:[NSData dataWithContentsOfURL:[NSURL URLWithString:@"http://b.hiphotos.baidu.com/image/pic/item/b219ebc4b74543a94369f4cb1c178a82b9011442.jpg"]]];

            dispatch_async(dispatch_get_main_queue(), ^{
            NSLog(@"-主线程-- 刷新UI--%@",[NSThread currentThread]);
            //回到主线程刷新UI
            self.imageView.image = image;
        });
    });
延时操作

延时操作不会堵塞当前线程.

//延迟操作
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(<#delayInSeconds#> * NSEC_PER_SEC)),//从什么时候开始,是一个固定的算法
                   dispatch_get_main_queue(),//队列
                   ^{
        //做要做的操作
    });
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

#pragma mark 延迟操作创建一
    //获取全局队列
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

    //延时多久
    dispatch_time_t whenTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3.0 * NSEC_PER_SEC));

    //延时操作,根据whenTime设计的时间
    dispatch_after(whenTime, queue, ^{
        NSLog(@"倒计时结束");

        dispatch_async(queue, ^{
            NSLog(@"-子线程-- 开始下载图片--%@",[NSThread currentThread]);

            //下载数据是耗时操作放到子线程
            UIImage *image = [UIImage imageWithData:[NSData dataWithContentsOfURL:[NSURL URLWithString:@"http://b.hiphotos.baidu.com/image/pic/item/b219ebc4b74543a94369f4cb1c178a82b9011442.jpg"]]];

            dispatch_async(dispatch_get_main_queue(), ^{
                NSLog(@"-主线程-- 刷新UI--%@",[NSThread currentThread]);

                //回到主线程刷新UI
                self.imageView.image = image;

            });
        });
    });
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

#pragma mark 延迟操作创建二
    //获取全局队列
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

        NSLog(@"倒计时结束");

        dispatch_async(queue, ^{
            NSLog(@"-子线程-- 开始下载图片--%@",[NSThread currentThread]);

            //下载数据是耗时操作放到子线程
            UIImage *image = [UIImage imageWithData:[NSData dataWithContentsOfURL:[NSURL URLWithString:@"http://b.hiphotos.baidu.com/image/pic/item/b219ebc4b74543a94369f4cb1c178a82b9011442.jpg"]]];

            dispatch_async(dispatch_get_main_queue(), ^{
                NSLog(@"-主线程-- 刷新UI--%@",[NSThread currentThread]);

                //回到主线程刷新UI
                self.imageView.image = image;
            });
        });
    });
GCD一次性代码
static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
            //代码只执行一次
    });
});
GCD队列组
分组模式 dispatch_group_notify

可以异步执行多个耗时操作。等耗时操作都执行完毕之后会回到主线程执行操作。主要用于监听任务是否完成。

//获取全局队列
    dispatch_queue_t globalQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    //创建一个队列组
    dispatch_group_t group = dispatch_group_create();

    dispatch_group_async(group, globalQueue, ^{

        NSLog(@"--- 1 开始--- %@",[NSThread currentThread]);
        //延时5秒 模仿堵塞子线程
        [NSThread sleepForTimeInterval:5];
        NSLog(@"--- 2 --- 完成 %@",[NSThread currentThread]);

    });

    dispatch_group_async(group, globalQueue, ^{

        NSLog(@"--- 2 开始--- %@",[NSThread currentThread]);
        //延时5秒 模仿堵塞子线程
        [NSThread sleepForTimeInterval:5];
        NSLog(@"--- 2 --- 完成 %@",[NSThread currentThread]);

    });

    //在这个队列组里面,会等group中的全部代码执行完毕再去执行其它的操作
    dispatch_group_notify(group, dispatch_get_main_queue(), ^{

        // 等前面的异步操作都执行完毕后,回到主线程...
        NSLog(@"全部完成");

    });

    //非ARC时候要释放掉
    //dispatch_release(group);
dispatch_apply组内无序循环执行任务
//循环执行任务,并且执行任务的顺序是无序列的。这里会堵塞当前的线程。所以要注意。一般都是在子线程中执行。
dispatch_apply(size_t iterations,//执行的次数
                   <#dispatch_queue_t queue#>,//队列
                   <#^(size_t)block#>)//任务
    dispatch_apply(5, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^(size_t index) {
        NSLog(@"%zu",index);
    });
dispatch_set_target_queue 变更queue的优先级别
dispatch_queue_t exampleQueue = dispatch_queue_create("com.example.queue", NULL);
    //设置这个全局并发队列的优先级为后台
    dispatch_queue_t globalQueued = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0);
    dispatch_set_target_queue(exampleQueue, globalQueued);
    /**
     *  经过转换之后exampleQueue的优先级别变成后台
     */

    • 0
      点赞
    • 0
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值