项目开发过程中经常使用了基于libuv库封装的库接口来实现异步处理,一直没仔细研究过这些接口的内部如何实现,因此也就没有掌握它的设计思想。今天花了点时间研究了其事件循环内部的一些过程,总算有了一些理解,理解还不够深刻,先记录下来:

1、循环流程

libuv源码分析

2、它的整体结构基于事件循环,简单的说就是外部的接口(如uv_write)其实是对内层的一个个请求,并没有做真正的事,这些请求都先存储在内部一个请求队列中,在事件循环(uv_run())中,再从请求队列中取出他们(uv_process_reqs),然后做具体的事情,做完了利用回调函数通知调用者,这样一来,所有的外部接口都可以变成异步的。

3、定时器的实现采用了最小堆的数据结构实现

4、内部采用了epoll 实现IO多路复用

 

参考链接:http://www.cnblogs.com/watercoldyi/p/5682344.html

              http://www.cnblogs.com/watercoldyi/p/5675180.html

相关文章:

  • 2021-06-27
  • 2021-12-28
  • 2021-05-18
  • 2021-04-12
  • 2021-05-20
  • 2021-09-10
  • 2021-10-27
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-07-07
  • 2022-12-23
  • 2021-09-03
  • 2021-08-15
  • 2021-08-15
相关资源
相似解决方案