文档章节

异步事件回调机制原理探索

m
 mirrorgdit
发布于 2016/04/11 15:14
字数 1143
阅读 26
收藏 0

软件组件之间,函数之间的调用分为:同步调用,函数指针形式的同步回调,异步调用。前面两种很简单无需多言,这里只探索下异步调用。

自定义的异步事件回调机制:

可以在自己的应用程序中,先注册事件和事件对应的回调函数(回调函数可以是函数指针法,虚函数方法的方式);自己程序中每帧检测事件是否发生或者条件是否满足,满足的时候就进入回调函数。如果这样的检查是在同一个线程中那么就是同步的延迟调用,如果是在子线程中就是异步调用,但是这样的性能还是比较差的,除非不得以,否则还是用OS的异步回调机制性能高。

OS层面的异步事件回调机制:

linux下的异步回调机制:

1.异步事件的注册:会在内核里面产生一个事件放置到事件队列(属于内核事件或者线程/进程事件队列,加入事件select,poll是O(n)算法效率,epoll是O(1)算法效率因为使用了mmap不需要从用户空间拷贝到内核空间,其它事件类似);该事件会记录当前线程/进程标识号,关联的内核文件设备驱动事件,还可能需要一个回调函数

2.异步事件的检测:检查时候会查询内核中的线程/进程事件队列(select,poll是O(n)算法效率,epoll是O(1)算法效率应该使用了数组类型的数据结构存储映射关系,其它事件类似 );阻塞线程/进程如果存在满足事件那么马上返回结果如果不满足将会挂起当前线程/进程,释放CPU占用,提高性能。 非阻塞的线程/进程条件满足返回结果,条件不满足那么返回非阻塞的信息,可以继续做其它事情

3.异步事件的回调驱动:文件设备驱动程序内有读写队列,当读写队列资源变为可读or写的时候(驱动程序可以周期性的检测读写队列而是计算机周期检测,非周期内驱动程序也可以挂起睡眠, 驱动程序也可以因为OS事件而唤醒,事件完成产生回调),将通过文件驱动资源和事件线程的关系(select poll o(n)算法效率内遍历事件队列,epoll O(1)时间算法效率,其它机制类似),唤醒在等待该资源的线程/进程继续执行(或发出事件通知到内核事件队列/线程进程的事件队列中)。唤醒后会再次判断文件设备条件是否满足因为非独占的资源可能被其它线程/进程获取了; 阻塞条件下成功了马上执行异步回调,返回中断现场继续执行程序逻辑,非阻塞条件下线程执行到此处检查事件队列将会成功从而产生异步调用,返回当时中断现场执行条件满足的后续逻辑,unity3d的coroutine也是这样的原理

windows下的异步回调机制:

回调事件注册和异步事件的驱动都和linux下类似。

只是检查异步事件的消息, windows内核有一个事件队列,内核也为当前的用户线程创建事件队列,当内核驱动触发事件(周期触发或OS通知触发)时,消息会被分发到内核事件队列,分发到当前线程事件队列;当前线程需要一个消息循环不断的获取消息,当然也提供了阻塞模式和非阻塞模式的检测消息(getmessage没有获得去到消息会阻塞挂起当前线程,peekmessage没有获取到消息返回FALSE不会阻塞挂起当前线程),接收到了消息要进行分发处理。

如图:

为了更清楚地说明这个问题,我们参看图1:

相关文章:

http://blog.csdn.net/zmxiangde_88/article/details/7963884

http://blog.chinaunix.net/uid-26851094-id-3175832.html

http://blog.csdn.net/a725sasa/article/details/12225685

http://www.ibm.com/developerworks/cn/linux/l-callback/

http://www.cppblog.com/mzty/archive/2006/11/24/15619.html

http://www.vckbase.com/index.php/wv/1593


http://downloadt.advantech.com/ProductFile/Downloadfile3/EI-3BTKK/FAQ-10.pdf

http://www.go-gddq.com/down/2012-03/12031720065032.pdf

本文转载自:

共有 人打赏支持
m
粉丝 3
博文 34
码字总数 36719
作品 0
深圳
高级程序员
Tornado 框架中异步与非阻塞编程代码说明

在tornad官方文档的Docs》User’s guide》Asynchronous and non-Blocking I/O部分,文中提供了几段示例代码: a、同步请求代码 from tornado.httpclient import HTTPClient def synchronous_...

张国凯
2015/04/25
0
0
探索Javascript异步编程

笔者在之前的一片博客中简单的讨论了Python和Javascript的异同,其实作为一种编程语言Javascript的异步编程是一个非常值得讨论的有趣话题。 JavaScript 异步编程简介 回调函数和异步执行 所谓...

naughty
2014/05/22
0
8
深入理解JavaScript定时机制

容易欺骗别人感情的JavaScript定时器 JavaScript的setTimeout与setInterval是两个很容易欺骗别人感情的方法,因为我们开始常常以为调用了就会按既定的方式执行, 我想不少人都深有同感, 例如 ...

四明狂客
2016/06/21
20
0
javascript中的定时器(How JavaScript Timers Work)

javascript定时器工作原理是一个重要的基础知识点。因为定时器在单线程中工作,它们表现出的行为很直观。我们该如何创建和维护定时器呢?要从如下三个函数(都是定义在全局作用域,在浏览器中...

隐性精神病人
2014/07/22
0
0
EventEmitter class

在Node中,要实现观察者模式非常的简单,而且内置于类中,类允许我们注册一个或者多个函数作为监听者,当对应的事件触发后,它们就会被触发 64C16489-985B-4083-823C-0A426D4F3C68.png 是一个...

一个胖子的我
2017/11/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

主流的消息队列MQ比较,详解MQ的4类应用场景

目前主流的MQ 1.ZeroMQ 号称最快的消息队列系统,尤其针对大吞吐量的需求场景。 扩展性好,开发比较灵活,采用C语言实现,实际上只是一个socket库的重新封装,如果做为消息队列使用,需要开发...

游人未归
47分钟前
2
0
React 服务器渲染原理解析与实践

网盘下载地址 React 服务器渲染原理解析与实践 本套课程,讲解了React中SSR技术的整个搭建思路及流程,完整的从原理上讲清楚了SSR的概念,重点在于讲解编写SSR框架遇到的各种知识点,以及细节...

qq__2304636824
今天
2
0
Jenkins使用

clean install -Dmaven.test.skip=true

1713716445
今天
1
0
多线程

1. 多线程概念。并发和并行的概念。 多线程指的是一段时间内cpu同时执行多个线程。一个程序至少运行>=1个进程,进程就是运行中的程序,而一个进程至少运行>=1个线程,线程是操作系统能调度的...

鱼想吃肉
今天
3
0
HBase 表修复在线方式和离线方式

一、在线修复 1.1 使用检查命令 $ ./bin/hbase hbck 该命令可完整修复 HBase 元数据信息;存在有错误信息会进行输出; 也可以通过如下命令查看详细信息: $ ./bin/hbase hbck -details 1.2 ...

Ryan-瑞恩
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部