今天遇到了這個問題,之前找了半天原來是IO事件的socket描述符在epoll_ctl()處理之前關閉了。
if(epoll_ctl(epollFd, EPOLL_CTL_DEL, ev->fd, &epv) < 0)
fprintf(stderr, "Event Del failed[fd=%d], epoll failed: %s\n",ev->fd, strerror(errno));
在刪除事件 epoll_ctl(kdpfd, EPOLL_CTL_DEL, events[n].data.fd,&ev);
之前 調用close()關閉socket描述符,
就會導致刪除事件時epoll_ctl()返回值小於0,並且提示epoll failed: Bad file descriptor
事件刪除后,再調用close()關閉對應的socket描述符就不會報錯了。