RunLoop的唤醒探索

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

内容简介:屏幕触摸事件,定时器事件是常见的可以唤醒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进入睡眠态。


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

查看所有标签

猜你喜欢:

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

Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)

Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)

刘长龙 / 电子工业出版社 / 2019-1 / 99

也许你听说过全栈工程师,他们善于设计系统架构,精通数据库建模、通用网络协议、后端并发处理、前端界面设计,在学术研究或工程项目上能独当一面。通过对Python 3及相关Web框架的学习和实践,你就可以成为这样的全能型人才。 《Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)》分为3篇:上篇是Python基础,带领初学者实践Python开发环境,掌握......一起来看看 《Python高效开发实战——Django、Tornado、Flask、Twisted(第2版)》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具