博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
IOS多线程学习六:GCD的其他用法
阅读量:3730 次
发布时间:2019-05-22

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

文章目录

一.延时执行

1. NSObject的方法[self performSelector]

2秒后再调用self的run方法

[self performSelector:@selector(run) withObject:nil afterDelay:2.0];

2.使用GCD函数,dispatch_after

2秒后异步执行这里的代码,dispatch_get_main_queue()表示回到主线程执行run

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

[self run];
})

3.[NSTimer scheduledTimerWithTimeInterval]

repeates:YES 的话就会重复,每2秒执行一次

[NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(run) userInfo:nil repeats:YES];

NSLog(@“111111”);
在这里插入图片描述

二. 一次性代码

使用dispatch_once函数能保证某段代码在程序运行工程中只被执行1次

static dispatch_once_t onceToken;

dispatch_once(&onceToken,^{
block//只执行一次的代码(这里面默认是线程安全的)
})
在这里插入图片描述

三.多次操作

每次调用apply,执行输出一次1111,执行10次输出index值,执行1次输出2222

在这里插入图片描述

四.队列组

有这么1种需求:

首先:分别异步执行2个耗时的操作
其次:等2个异步操作都执行完毕后,再回到主线程执行操作。

dispatch_group_t group=dispatch_group_create();

dispatch_group_async(group,dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0),^{
//执行1个耗时的异步操作
});
dispatch_group_async(group,dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0),^{
//执行1个耗时的异步操作
});
dispatch_group_notify(group,dispatch_get_main_queue(),^{
//等前面的异步操作都执行完毕后,回到主线程。。
});

在这里插入图片描述

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

你可能感兴趣的文章
数据结构之链表及常见题
查看>>
数据结构之单向环形链表(约瑟夫问题)
查看>>
数据结构之栈(前、中、后缀表达式)
查看>>
递归应用场景和调用机制
查看>>
四种方法带你解析xml文件和xml字符串
查看>>
启动Hadoop没有dataNode进程的解决办法
查看>>
听说redis集群没有pipeLine,看这里,博主带你重构redisCluter pipeLine
查看>>
flink高性能写入关系型数据库Oracle或者MySql
查看>>
关于时序数据流经Kafka之后可能产生乱序的原因和解决方法
查看>>
flink以gz格式写入hdfs
查看>>
解决Mysql连接8小时空闲失效问题
查看>>
flink配合druid连接池的使用
查看>>
博主带你深入理解JVM
查看>>
23种设计模式前言
查看>>
设计模式之单例模式和工厂模式
查看>>
flink state TTL(Time To Live) 如何应对飞速增长的状态?checkpoint机制原理?
查看>>
那些年,我们一起使用过的case...when
查看>>
flink之内存分配与内存管理
查看>>
一篇由flink akka timeoutException引发的slot和parallelism
查看>>
flink批量(batch)写入mysql/oracle
查看>>