dispatch_time_t

写在最前面:
转自:https://blog.csdn.net/wpeng20125/article/details/73650569
对原文作了下排版利于理解,也感谢原文作者为我们说明这个函数

dispatch_time_t 类型,它的创建有两个函数

    1. dispatch_time(<#dispatch_time_t when#>, <#int64_t delta#>)
      第一个参数是从什么时间开始,一般直接传
      DISPATCH_TIME_NOW 表示从现在开始
      第二个参数表示具体的时间长度(不能直接传 int 或 float), 可以写成这种形式 (int64_t)3* NSEC_PER_SEC
        #define NSEC_PER_MSEC 1000000ull    每毫秒有1000000纳秒
        #define USEC_PER_SEC 1000000ull     每秒有1000000微秒
        #define NSEC_PER_USEC 1000ull       每微秒有1000纳秒

注意 delta 的单位是纳秒!
1秒的写作方式可以是 1* NSEC_PER_SEC; 1000* NSEC_PER_MSECUSEC_PER_SEC* NSEC_PER_USEC

  • 2.dispatch_walltime(<#const struct timespec * _Nullable when#>, <#int64_t delta#>),
    第一个参数是一个结构体, 创建的是一个绝对的时间点,比如 2016年10月10日8点30分30秒, 如果你不需要自某一个特定的时刻开始,可以传 NUll,表示自动获取当前时区的当前时间作为开始时刻, 第二参数意义同第一个函数
    dispatch_time_t time = dispatch_walltime(NULL, 5* NSEC_PER_SEC);

两个函数的不同
例如:
从现在开始,1小时之后是触发某个事件

使用第一个函数创建的是一个相对的时间,第一个参数开始时间参考的是当前系统的时钟,当 device 进入休眠之后,系统的时钟也会进入休眠状态, 第一个函数同样被挂起; 假如 device 在第一个函数开始执行后10分钟进入了休眠状态,那么这个函数同时也会停止执行,当你再次唤醒 device 之后,该函数同时被唤醒,但是事件的触发就变成了从唤醒 device 的时刻开始,1小时之后.

而第二个函数则不同,他创建的是一个绝对的时间点,一旦创建就表示从这个时间点开始,1小时之后触发事件,假如 device 休眠了10分钟,当再次唤醒 device 的时候,计算时间间隔的时间起点还是,开始时就设置的那个时间点, 而不会受到 device 是否进入休眠影响

你可能感兴趣的:(dispatch_time_t)