为什么moduo库要进行线程检查

问题描述:

在moduo库中调用runloop时会做线程检测

判断当前线程是否为事件循环所属线程,若检测不通过,相关操作不会在当前线程执行,而是会被封装后路由到对应的 IO 线程中执行。

我之前一直疑惑:既然每一个线程都有一个 EventLoop , EventLoop都会有一个poller ,且poller仅负责检测 EventLoop 中注册的 Channel 。那为什么还要进行线程检查呢。

核心原因

其他线程(如业务线程、定时器线程)可能发起对 IO 线程所属 Channel(及关联的 EventLoop/Poller)的修改操作(例如开启 / 关闭 Channel 读写事件、移除 Channel 监听等); 在多个线程中进行修改会导致线程安全等问题,因而强制所有修改/执行IO操作都在IO线程中完成。

例如:

  • 业务线程主动推送消息

​ 需要让 连接的 Channel 增加可写事件

  • 心跳检测关闭不活跃的连接

​ 需要为对应 Channel 禁用所有事件并移除监听。

其他优点:

  • 易用性:业务层不需要考虑调用哪个线程执行操作
  • 保证了 one loop per thread 的稳定性,隔离了 IO线程操作于业务的操作。
    per thread 的稳定性,隔离了 IO线程操作于业务的操作。
  • 性能层面:按需线程切换,减少不必要的开销。可以批量处理任务,减少系统调用的次数。
相关推荐
美式请加冰几秒前
异常的介绍和使用
开发语言·c++
coding者在努力14 分钟前
算法竞赛中根据数据规模猜测算法
c++·算法·stl·时间复杂度
jing-ya17 分钟前
day 59 图论part10
java·开发语言·数据结构·算法·图论
love530love18 分钟前
ComfyUI-3D-Pack:Windows 下手动编译 mesh_inpaint_processor C++ 加速模块
c++·人工智能·windows·python·3d·hunyuan3d·comfyui-3d-pack
嵌入式-老费22 分钟前
vivado hls的应用(第一个axi接口的ip)
linux·服务器·tcp/ip
楼田莉子24 分钟前
C++高并发内存池:内存池调优与测试
c++·后端·哈希算法·visual studio
雾隐潇湘36 分钟前
C++——第三篇 继承与多态
开发语言·c++
Marye_爱吃樱桃37 分钟前
MATLAB R2024b的安装、简单设置——保姆级教程
开发语言·matlab
旺仔.29137 分钟前
Linux系统基础详解(二)
linux·开发语言·网络
阿贵---38 分钟前
分布式系统C++实现
开发语言·c++·算法