iOS多线程-GCD之常用函数
延迟执行任务函数dispatch_after(.....)
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
NSLog(@"start");
//dispatch_after 是异步执行的
//队列只决定在哪个线程中执行任务 并不能决定执行时间
/**
* 第一个参数: 在哪个时间点执行
* dispatch_time(从哪个时间点开始,经历多少纳秒)
* 第二个参数: 在哪个队列中执行block任务
* 第三个参数: block任务
*/
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
NSLog(@"%@",[NSThread currentThread]);
});
NSLog(@"end");
}
一次性执行dispatch_once(...)
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
//一次性执行的机制,能保证在程序启动后只会执行一次,并且是线程安全的,在主线程中执行
//一般使用dispatch_once来做一次性执行,效率高, 在单例模式中使用.
//可以利用互斥锁在实现此功能,但不建议使用,因为效率非常低!!!!
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
NSLog(@"");
});
}栅栏函数dispatch_barrier_async/dispatch_barrier_sync
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{ dispatch_queue_t queue = dispatch_queue_create("yuxuan", DISPATCH_QUEUE_CONCURRENT); dispatch_async(queue, ^{
NSLog(@"任务1");
}); dispatch_async(queue, ^{
NSLog(@"任务2");
}); //栅栏函数(同步函数就没必要控制顺序了,因为它是有序的)
//dispatch_barrier_async 是异步函数不会阻塞线程
//dispatch_barrier_sync 是同步函数 会阻塞线程
//如果所有任务都在同一个并行队列中,并且这个并行队列不是系统自带全局并行队列
//哪么在barrier之前添加的方法会先被执行,只有等barrier之前的任务执行完毕后才会执行barrier任务
//只有barrier任务执行完毕后,才会执行后添加的任务
dispatch_barrier_async(queue, ^{
NSLog(@"我是个可爱的路障");
}); dispatch_async(queue, ^{
NSLog(@"任务3");
}); dispatch_async(queue, ^{
NSLog(@"任务4");
}); NSLog(@"end");
}队列组的使用dispatch_group_t
方式一:
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{ //创建一个队列组
dispatch_group_t group = dispatch_group_create(); //创建两个不同的队列来测试
dispatch_queue_t queue1 = dispatch_get_global_queue(0, 0); dispatch_queue_t queue2 = dispatch_queue_create("yuxuan", DISPATCH_QUEUE_CONCURRENT); //dispatch_group_async 异步函数
//系统会先把任务放入队列中,然后把队列放入组中
//从组中把队列取出来,在从队列里取任务执行
dispatch_group_async(group, queue1, ^{
[NSThread sleepForTimeInterval:1.0];
NSLog(@"download 1");
}); dispatch_group_async(group, queue2, ^{
[NSThread sleepForTimeInterval:1.0];
NSLog(@"download 2");
});
//给group添加一个通知,异步函数
//当group队列中所有任务执行完毕,就会通知group执行block
/*
* 第一个参数: 为那个队列组添加通知
* 第二个参数: 决定block在什么线程中执行
* 第三个参数: block 代码块
*/
dispatch_group_notify(group, dispatch_queue_create("yuxuan1",DISPATCH_QUEUE_CONCURRENT), ^{
NSLog(@"OK");
});
NSLog(@"end");
}方式二:
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
/*
dispatch_group_async底层实现:
void dispatch_group_async(dispatch_group_t group, dispatch_queue_t queue, dispatch_block_t block)
{
dispatch_retain(group);
dispatch_group_enter(group);
dispatch_async(queue, ^{
block();
dispatch_group_leave(group);
dispatch_release(group);
});
}
*/
dispatch_queue_t queue = dispatch_get_global_queue(0, 0); //创建一个队列组
dispatch_group_t group = dispatch_group_create(); //通知队列组进入队列组
dispatch_group_enter(group); dispatch_async(queue, ^{
NSLog(@"111");
//任务执行完毕
//通知队列组离开队列组
dispatch_group_leave(group);
}); //通知队列组进入队列组
dispatch_group_enter(group); dispatch_async(queue, ^{
NSLog(@"222");
//任务执行完毕
//通知队列组离开队列组
dispatch_group_leave(group);
}); //等待所有任务执行完毕,一直等待.会阻塞线程
dispatch_group_wait(group, DISPATCH_TIME_FOREVER); // dispatch_group_notify(group, queue, ^{
// NSLog(@"over");
// });
}
GCD定时器
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
//创建一个队列,创建GCD定时器时使用
dispatch_queue_t queue = dispatch_queue_create("yuxuan", DISPATCH_QUEUE_SERIAL);
//创建一个GCD定时器(触发器)
//第四个参数:传入一个队列,决定了定时器回调任务执行方式.
dispatch_source_t timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue);
//dispatch_source_t其实本质是一个类,由于是局部变量,方法执行完,就会被释放.
self.timer = timer;
//设置定时器
/*
第一个参数:给那个定时器设置
第二个参数:什么时候启动
第三个参数:间隔多久执行一次
第四个参数:设置精准度:0 代表最高精准(尽量让定时器精准), 大于0的的话代表是在多少秒内接受.
第四个参数存在意义:主要是为了提高程序性能, 设置越大,能减轻CPU的压力
注意:GCD定时器传入的时间都是纳秒
*/
dispatch_source_set_timer(timer, DISPATCH_TIME_NOW, 1.0 * NSEC_PER_SEC, 0.0 * NSEC_PER_SEC);
//第一个参数:给那个定时器设置
//第二个参数:设置定时器回调block
//异步执行的,具有创建新线程的能力
//具体是否创建线程,创建几条线程是由定时任务创建时,传入的queue决定的
dispatch_source_set_event_handler(timer, ^{
NSLog(@"%@",[NSThread currentThread]);
});
//启动定时器
dispatch_resume(timer);
}
iOS多线程-GCD之常用函数的更多相关文章
- iOS多线程 GCD
iOS多线程 GCD Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main que ...
- iOS 多线程 GCD part3:API
https://www.jianshu.com/p/072111f5889d 2017.03.05 22:54* 字数 1667 阅读 88评论 0喜欢 1 0. 预备知识 GCD对时间的描述有些新奇 ...
- iOS 多线程GCD的基本使用
<iOS多线程简介>中提到:GCD中有2个核心概念:1.任务(执行什么操作)2.队列(用来存放任务) 那么多线程GCD的基本使用有哪些呢? 可以分以下多种情况: 1.异步函数 + 并发队列 ...
- iOS 多线程GCD简介
一.简介 1.1 GCD (Grand Central Dispatch )是Apple开发的一个多核编程的解决方法. Grand 含义是“伟大的.宏大的”,Central含义“中央的”,Dispat ...
- iOS多线程GCD的使用
1. GCD 简介 Grand Central Dispatch(GCD)是异步执行任务的技术之一.一般将应用程序中记述的线程管理用的代码在系统级中实现.开发者只需要定义想执行的任务并追加到适当的Di ...
- iOS - 多线程——GCD
什么是GCD Grand Central Dispatch(强大的调度器),是一个C语言API: 作用:多核并行运算的解决方案: GCD中有2个核心概念 ...
- ios多线程开发的常用三种方式
1.NSThread 2.NSOperationQueue 3.GCD NSThread: 创建方式主要有两种: [NSThread detachNewThreadSelector:@selector ...
- iOS多线程——GCD与NSOperation总结
很长时间以来,我个人(可能还有很多同学),对多线程编程都存在一些误解.一个很明显的表现是,很多人有这样的看法: 新开一个线程,能提高速度,避免阻塞主线程 毕竟多线程嘛,几个线程一起跑任务,速度快,还不 ...
- iOS多线程GCD详解
在这之前,一直有个疑问就是:gcd的系统管理多线程的概念,如果你看到gcd管理多线程你肯定也有这样的疑问,就是:并发队列怎么回事,即是队列(先进先出)怎么会并发,本人郁闷了好久,才发现其实cgd管理多 ...
随机推荐
- XML简介与CDATA解释
简介XML 是一种受到广泛支持的 Internet 标准,用于以一种特殊的方式编码结构化数据.实际上,以 XML 编码的数据可以通过任何编程语言解码,人们甚至可以使用标准的文本编辑器来阅读或编写 XM ...
- AutoMapper的使用
1.AutoMapper简单介绍 官网:http://automapper.org/ 源码:https://github.com/AutoMapper/AutoMapper NUGET安装: PM&g ...
- 在html中添加script脚本的方法和注意事项
在html中添加script脚本有两种方法,直接将javascript代码添加到html中与添加外部js文件,这两种方法都比较常用,大家可以根据自己需要自由选择 在html中添加<script& ...
- Linux之sar命令介绍
sar(System Activity Reporter系统活动情况报告)是目前 Linux 上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告,包括:文件的读写情况.系统调用的使用情 ...
- 【Quartz】将定时任务持久化到数据库
之前的文章所做的demo是将定时任务的信息保存在内存中的,见以下配置 org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore 如果,我们需要在 ...
- Jenkins创建Maven项目及SSH部署
前面我们已经安装了Jenkins的环境,以及配置好了jdk和maven.下面我们来看如何通过Jenkins将svn的项目进行打包和部署. 创建MAVEN项目 1.点击新建,输入项目名,选择" ...
- 关于Django 错误 doesn't declare an explicit app_label and isn't in an application in INSTALLED_APPS
记录一下 报错 doesn't declare an explicit app_label and isn't in an application in INSTALLED_APPS\ 这个问题出现没 ...
- virtualenv 安装使用
不同的人喜欢用不同的方式建立各自的开发环境,但在几乎所有的编程社区,总有一个(或一个以上)开发环境让人更容易接受. 使用不同的开发环境虽然没有什么错误,但有些环境设置更容易进行便利的测试,并做一些 ...
- vector迭代器用法
#include<iostream> #include<vector> using namespace std; int main() { vector<int> ...
- html5定位getLocation()
HTML5 Geolocation API 用于获得用户的地理位置. 如果用户不允许定位,那么用户信息是不可用的. 获取用户的位置:getCurrentPosition() 返回数据如下 返回用户当前 ...