Libuv多路事件循环(Multiple event loops)

转载 2016年08月31日 16:38:47

Libuv多路事件循环(Multiple event loops)

文章目录

你也可以在同一个线程中使用多路事件循环, 但意义并不大, 因为调用其中某一个事件循环的 uv_run 会使得程序阻塞, 其他事件循环不能同时运行. 不过也可以小心地通过多次调用 uv_run_once() 来完成一些有趣的工作.

多路事件循环的形式(Modality)

你可以在你的程序中按照相对标准方式使用多路事件循环, 即第二个事件循环先暂停第一个事件循环, 直到发生了动作(用户按下了 Return(Enter) 键, 或者发生了新的事件等).

各线程拥有自己的事件循环(One loop per thread)

One loop per thread 才是多路事件循环的’标准模型’, 它和我们在 进程 一章中介绍的产生多个进程方式并无太大区别.

使用两个事件循环来同步(sing two loops for synchronization)

也有一些比较特殊的应用场景需要两个事件循环来进行同步(而不是使用条件变量), 在 node-taglib 库中我就使用了这种同步机制. 具体的应用场景如下:

  1. 主线程 main thread 通过 uv_queue_work 在工作线程中调用一个阻塞函数.
  2. 工作线程 worker thread 调用一个自定义函数, 并且自定义函数必须在主线程中运行.
  3. 工作线程一直等待, 直到函数返回.

如果使用条件变量来实现:

  1. 工作线程并不直接调用自定义函数, 而是创建一个 uv_async_t 句柄, 然后由该句柄的回调函数调用自定义函数.
  2. 初始化条件变量.
  3. 使用 uv_async_send() 获得主线程(运行事件循环的线程)并由主线程调用该函数.
  4. 等待条件变量的通知.
  5. 回调函数调用自定义函数, 并向条件变量发送通知, 使得工作线程得以继续下去.

而事件循环的实现方式为:

  1. 在工作线程中创建一个新的事件循环.
  2. uv_async_t 与事件循环相关联.
  3. 将该句柄通过 uv_async_t 结构 data 字段传递给主线程.
  4. uv_run() 运行事件循环, 此时程序会阻塞, 因为异步句柄自增了它的 refcount.
  5. 主线程的回调函数再调用自定义函数,然后调用 uv_async_send 向事件循环的异步句柄发送消息.
  6. 异步句柄的回调函数关闭自己, 然后事件循环的引用计数减为 0, uv_run 返回, 工作线程得以继续下去.

相关文章推荐

libuv之事件循环loop

libuv强制使用异步的,事件驱动的编程风格。它的核心工作是提供一个event-loop,还有基于I/O和其它事件通知的回调函数。libuv还提供了一些核心工具,例如定时器,非阻塞的网络支持,异步文件...
  • js_gary
  • js_gary
  • 2017年05月16日 16:52
  • 684

libuv里的几个缺陷

libuv是node.js使用的基础库,主要包括主循环,文件和网络接口。虽然libuv是为node.js而生的,但它本身是一个独立的库,加上使用简单方便,所以在node.js之外也有不少人使用。最近整...
  • absurd
  • absurd
  • 2015年08月30日 10:18
  • 21496

libuv 使用中的一些个人认识

--------------我会跟进纠正或补充,有错误的请各位指教!!! 1、如果用libuv,那就尽量都用它,循环,文件读写,线程等; 2、只有uv_async_t是线程安全的,配套uv_as...

libuv之线程池的坑,注意避免

libuv的uv_queue_work 使用,不能在fork的子进程中使用,原因未调查清楚,记录一下! 望有清楚的提点一下,谢谢...

libuv学习笔记(2)

libuv学习笔记(2) uv_loop_t结构体以及相关函数(windows平台)

基于libuv的TCP设计

本人一直在寻找一个跨平台的网络库,
  • wqvbjhc
  • wqvbjhc
  • 2014年05月15日 23:43
  • 12707

libuv多线程处理的简单示例

简介 libuv提供了多线程处理的封装,使用起来也非常简单,一个handle,即uv_thread_t,在linux环境下,就是pthread_t,也就是unsigned long类型。相关的三个函数...

libuv的线程池,即工作队列

1. 在使用libuv的时候,发现使用其提供的 uv_queue_work 的确可为用户的某一任务放在单独的线程中执行。但是只能同时执行4个。 2. 介绍一下libuv的工作队列,http://www...

库-libuv:概述

libuv 是 Node 的新跨平台抽象层,用于抽象 Windows 的 IOCP 及 Unix 的 libev。作者打算在这个库的包含所有平台的差异性。 特性: 非阻塞 TCP 套接字 ...

M95251 Louis Vuitton handbag Shanghai Hong Kong and Macau are available online renewal endorsement

newspaper Shanghai Feb. 8 (Xinhua package Jian ) Shanghai public security authorities recently laun...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Libuv多路事件循环(Multiple event loops)
举报原因:
原因补充:

(最多只允许输入30个字)