我想,如果我没有在 child 中调用ev_loop_fork,那么 child 中的 watcher 就不会被触发。
这是我的代码,我用EVBACKEND_EPOLL和EVFLAG_NOENV标志构建了 ev_loop。
所以没有EVFLAG_FORKCHECK标志。
然后我在孩子中评论ev_loop_fork调用。
如果一切顺利,我以为孩子不会触发超时回调函数。
但实际上,输出是这样的:
$ 4980 叉子 4981
$ 超时 4980
$ 超时 4981
似乎观察者仍然在孩子中被触发,它的行为与调用ev_loop_fork相同。
那是什么问题,谢谢。
#include<ev.h>
#include<stdio.h>
#include<unistd.h>
void timeout_cb(EV_P_ ev_timer *w,int revents)
{
printf("time out at %d\n", getpid());
ev_break(EV_A_ EVBREAK_ONE);
}
int main()
{
int ret;
ev_timer timeout_watcher;
struct ev_loop *loop = ev_default_loop(EVBACKEND_EPOLL | EVFLAG_NOENV);
ev_timer_init(&timeout_watcher,timeout_cb,5.5,0.);
ev_timer_start(loop,&timeout_watcher);
ret = fork();
if(ret>0) printf("%d fork %d\n",getpid(),ret);
else if(ret==0)
{
//ev_loop_fork(EV_DEFAULT);
}
else return -1;
ev_run(loop,0);
return 0;
}