为什么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线程操作于业务的操作。
  • 性能层面:按需线程切换,减少不必要的开销。可以批量处理任务,减少系统调用的次数。
相关推荐
洒家肉山大魔王1 小时前
Kubernetes中Pod 处于 CrashLoopBackOff 状态(生产环境)
linux·容器·kubernetes·pod·pod循环重启
GIS阵地1 小时前
Qt实现简易仪表盘
开发语言·c++·qt·pyqt·qgis·qt5·地理信息系统
天天摸鱼的小学生1 小时前
【Java Enum枚举】
java·开发语言
崇山峻岭之间1 小时前
C++ Prime Plus 学习笔记028
c++·笔记·学习
阿猿收手吧!1 小时前
【C++】cpp虚函数和纯虚函数的声明和定义
开发语言·c++
q_30238195561 小时前
Python实现基于多模态知识图谱的中医智能辅助诊疗系统:迈向智慧中医的新篇章
开发语言·python·知识图谱
小武~1 小时前
Leetcode 每日一题C 语言版 -- 234 basic calculator
linux·c语言·leetcode
橘颂TA1 小时前
【Linux】System V 通信——共享内存
linux·运维·服务器·c++
梨落秋霜1 小时前
Python入门篇【输入input】
开发语言·python