如何确定文件描述符是否附加到Linux中的文件或套接字

时间:2013-11-11 02:11:33

标签: c linux sockets unix posix

在Linux中使用C语言,如何判断文件描述符是否附加到文件或套接字?

3 个答案:

答案 0 :(得分:7)

使用getsockopt获取文件描述符上的SO_TYPE。如果它不是套接字,它将返回-1,错误为ENOTSOCK

int fd = /* ... */;
bool is_socket;
int socket_type;
socklen_t length = sizeof(socket_type);

if(getsockopt(fd, SOL_SOCKET, SO_TYPE, &socket_type, &length) != -1) {
    is_socket = true;
} else {
    if(errno == ENOTSOCK) {
        is_socket = false;
    } else {
        abort();  /* genuine error */
    }
}

/* whether it is a socket will be stored in is_socket */

答案 1 :(得分:7)

或者,您可以使用fstatS_ISSOCK宏。

int main(int argc, char *argv[])
{
    int fds[2];

    fds[0] = 0; //stdin
    fds[1] = socket(AF_INET,SOCK_STREAM, 0);

    for (int i = 0; i < 2; ++i)
    {
        struct stat statbuf;

        if (fstat(fds[i], &statbuf) == -1)
        {
            perror("fstat");
            exit(1);
        }

        if (S_ISSOCK(statbuf.st_mode))
            printf("%d is a socket\n", fds[i]);
        else
            printf("%d is NOT a socket\n", fds[i]);
    }

    return(0);
}

答案 2 :(得分:0)

根据socket(7) man page

  

套接字不支持寻找或调用具有非零位置的pread(2)或pwrite(2)。

因此,另一个选择是执行其中一个不受支持的操作,看看是否收到错误。如果你设法寻找,那么FD可能是一个文件(或设备)。否则它可能是一个套接字。或管道。