RunLoop的唤醒探索

栏目: IOS · 发布时间: 6年前

内容简介:屏幕触摸事件,定时器事件是常见的可以唤醒runLoop的事件。但是我们很少去关注定时器是怎么唤醒额runLoop,唤醒后又进行了哪些操作。我们也很少关注我们触摸屏幕如点击一个按钮,是如何唤醒的runLoopo,唤醒多经历了哪些过程,点击完按钮又执行了什么。下边让我们来逐一探索。

屏幕触摸事件,定时器事件是常见的可以唤醒runLoop的事件。但是我们很少去关注定时器是怎么唤醒额runLoop,唤醒后又进行了哪些操作。我们也很少关注我们触摸屏幕如点击一个按钮,是如何唤醒的runLoopo,唤醒多经历了哪些过程,点击完按钮又执行了什么。下边让我们来逐一探索。

定时器事件唤醒runLoop

  1. 首先我们先写个类去监听runLoop的状态
@implementation MainRunLoopObsever
+ (void)load{
    CFRunLoopObserverRef obseverRef = CFRunLoopObserverCreateWithHandler(CFAllocatorGetDefault(), kCFRunLoopAllActivities, YES, 0, ^(CFRunLoopObserverRef observer, CFRunLoopActivity activity) {
        NSString *str = nil;
        switch (activity) {
            case kCFRunLoopEntry:
                str = @"kCFRunLoopEntry";
                break;
            case kCFRunLoopBeforeTimers:
                str = @"kCFRunLoopBeforeTimers";
                break;
            case kCFRunLoopBeforeSources:
                str = @"kCFRunLoopBeforeSources";
                break;
            case kCFRunLoopBeforeWaiting:
                str = @"kCFRunLoopBeforeWaiting";
                break;
            case kCFRunLoopExit:
                str = @"kCFRunLoopExit";
                break;
            case kCFRunLoopAllActivities:
                str = @"kCFRunLoopAllActivities";
                break;
            case kCFRunLoopAfterWaiting:
                str = @"kCFRunLoopAfterWaiting";
                break;
                
            default:
                break;
        }
        if (str == nil) {
            NSLog(@"%ld",activity);
        }else{
            NSLog(@"%@",str);
        }
    });
    
    CFRunLoopAddObserver(CFRunLoopGetMain(), obseverRef, kCFRunLoopCommonModes);
}
@end

复制代码
  1. 之后再写定时器代码
@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    [NSTimer scheduledTimerWithTimeInterval:10.0 repeats:YES block:^(NSTimer * _Nonnull timer) {
        NSLog(@"timer事件");
    }];
}

@end
复制代码
  1. 观察控制台的打印

    在NSLog部分打个断点,程序运行起来,观察控制台的打印。发现在控制台输入kCFRunLoopAfterWaiting之后进入了断点执行了我们写的block,之后我们在解除断点跑起来程序发现之后依次输出timer事件,kCFRunLoopBeforeTimers,kCFRunLoopBeforeSources,kCFRunLoopBeforeWaiting。

    说明定时器事件唤醒了runLoop之后执行了kCFRunLoopAfterWaiting这个obsever。之后执行我们的定时任务输出timer事件,在执行完毕后执行了kCFRunLoopBeforeTimers(obsever),再之后执行了kCFRunLoopBeforeSources(obsever),最后执行了kCFRunLoopBeforeWaiting(obsever)。之后其实要倾倒释放池,重新创建新的释放池,并更新UI,最后CPU进入睡眠态。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人类思维如何与互联网共同进化

人类思维如何与互联网共同进化

[美] 约翰·布罗克曼 / 付晓光 / 浙江人民出版社 / 2017-3 / 79.90元

➢人类是否因互联网的诞生进入了公平竞争的场域? “黑天鹅事件”频频发生,我们的预测能力是否正在退化? 智人的第四阶段有哪些特征? 全球脑会使人类成为“超级英雄”吗? 虚拟现实技术会不会灭绝人类的真实体验? 还有更多不可预知答案的问题,你将在本书中找到属于自己的答案! ➢ 我们的心智正和互联网发生着永无止境的共振,人类思维会因此产生怎样的进化效应?本书编者约翰•布......一起来看看 《人类思维如何与互联网共同进化》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具