poll() return POLLERR 什么时候开始

when does poll() return POLLERR

server.c -> 总是recv客户端数据(使用poll()确认是否出错)

client.c -> 始终向服务器发送数据

我执行 server.cclient.c,然后我尝试终止 client.c 进程。

但是永远不会设置 POLLERR 标志。

手册页只说

POLLERR Error condition (output only)

Poll() return POLLERR 什么时候开始?

我错过了什么?

谢谢。

server.c

#include <stdio.h>
#include <stdlib.h>
#include <sys/poll.h>
#include <sys/socket.h>
#include <sys/time.h>
#include <netinet/in.h>
#include <errno.h>

int main()
{
    int rc = 0;
    char str[100];
    char test[5];
    int listen_fd, comm_fd;
    struct sockaddr_in servaddr;
    struct pollfd fds[200];
    listen_fd = socket(AF_INET, SOCK_STREAM, 0);

    servaddr.sin_family = AF_INET;
    servaddr.sin_addr.s_addr = htons(INADDR_ANY);
    servaddr.sin_port = htons(22000);

    bind(listen_fd, (struct sockaddr *) &servaddr, sizeof(servaddr));
    listen(listen_fd, 10);
    comm_fd = accept(listen_fd, (struct sockaddr*) NULL, NULL);
    fds[0].fd = comm_fd;
    fds[0].events = POLLIN | POLLOUT | POLLERR | POLLHUP;
    printf("start\n");

    while(1) {
        rc = poll(fds,1,1000);
        if (rc < 0)
            printf("failed\n");
        else if(rc==0)
            printf("timeout\n");
        else {
            if (fds[0].revents & POLLERR){
                printf("Error!!\n");
            }


            if(fds[0].revents & POLLHUP){
                printf("handup!!\n");
                break;
            }

            if (fds[0].revents & POLLIN){
                int bl = recv(comm_fd,test,4,0);
                printf("recv:%s %d\n",test,bl);
            }
        }
        sleep(1);

    }
    return 0;
}

client.c

#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <stdio.h>
#include <string.h>

int main(int argc,char **argv)
{
    int sockfd,n;
    char sendline[100];
    char recvline[100];
    struct sockaddr_in servaddr;

    sockfd=socket(AF_INET,SOCK_STREAM,0);
    bzero(&servaddr,sizeof servaddr);

    servaddr.sin_family=AF_INET;
    servaddr.sin_port=htons(22000);

    inet_pton(AF_INET,"127.0.0.1",&(servaddr.sin_addr));

    connect(sockfd,(struct sockaddr *)&servaddr,sizeof(servaddr));
    while(1){
        send(sockfd,"test",4,0); 
        sleep(5);
    } 
    close(sockfd);
    return 0;
}

它取决于实现。大多数应用程序只是将 POLLERR 视为正常就绪,允许后续操作失败。