libevent的多线程信号注意点
来源:互联网 发布:演奏音乐的软件 编辑:程序博客网 时间:2024/06/01 09:08
http://blog.csdn.net/sparkliang/article/details/5306809
前面讲到了 libevent 实现多线程的方法,然而在多线程的环境中注册信号事件,还是有一些情况需要小心处理,那就是不能在多个 libevent 实例上注册信号事件。依然冠名追加到 libevent 系列。
以 2 个线程为例,做简单的场景分析。
1 首先是创建并初始化线程 1 的 libevent 实例 base1 ,线程 1 的 libevent 实例 base2 ;
2 在 base1 上注册 SIGALRM 信号;在 base2 上注册 SIGINT 信号;
3 假设当前 base1 和 base2 上都没有注册其他的事件;
4 线程 1 和 2 都进入 event_base_loop 事件循环:
event_base_loop(base1) event_base_loop(base2)
{ {
if (base2->sig.ev_signal_added) if (base2->sig.ev_signal_added)
evsignal_base = base1; evsignal_base = base2;
while(!done) while(!done)
{ {
… …
evsel->dispatch(…); evsel->dispatch(…);
… …
} }
} }
5 假设线程 1 先进入 event_base_loop ,并设置 evsignal_base = base1 ;并等待;
6 接着线程 2 也进入 event_base_loop ,并设置 evsignal_base = base2 ;并等待;
于是 evsignal_base 就指向了 base2 ;
7 信号 ALARM 触发,调用服务例程:
static void evsignal_handler(int sig)
{
...
evsignal_base->sig.evsigcaught[sig]++;
evsignal_base->sig.evsignal_caught = 1;
/* Wake up our notification mechanism */
send(evsignal_base->sig.ev_signal_pair[0], "a", 1, 0);
...
}
于是 base2 得到通知 ALARM 信号发生了,而实际上 ALARM 是注册在 base1 上的, base2 上的 ALARM注册 event 是空的,于是处理函数将不能得到调用;
因此在 libevent 中,如果需要处理信号,只能将信号注册到一个 libevent 实例上。
memcached 就没有使用 libevent 提供的 signal 接口,而是直接使用系统提供的原生 API ,看起来这样更简洁。
- libevent的多线程信号注意点
- libevent源码深度剖析十三——libevent信号处理注意点
- libevent源码深度剖析十三——libevent信号处理注意点
- 自定义的信号和槽注意点
- 多线程的使用注意点
- Libevent信号event的处理
- libevent的集成信号处理
- 多线程编程需要注意的几点
- 关于多线程的几点注意
- JAVA多线程的一些注意点
- QT 信号和槽需要注意的几点
- 多线程程序注意点
- 多线程编程注意点
- java多线程注意点
- libevent源码分析--libevent库对信号事件的处理
- Libevent源码分析-----信号event的处理
- Libevent源码分析-----信号event的处理
- Libevent源码分析-----信号event的处理
- Wireshake打开时显示无可用的抓包口
- jquery 给一组单选赋值或取值
- android4.1(QHD4500)声音驱动调试
- hibernate 分页查询的bug
- Play!framework 项目部署到Tomcat
- libevent的多线程信号注意点
- 调用webservice,解析返回数据为xml格式的字符串,进行数据绑定
- 深度优先遍历算法--非递归实现
- 归属于母公司所有者净利润
- 状态压缩DP——poj3254Corn Fields
- oracle存储过程--游标
- Android GCM使用
- 动态调用DLL函数有时正常,有时报Access violation的异常
- Oracle数据库编程:PL/SQL编程基础