为什么我们在调用 dup2 后关闭文件描述符?

Why do we close the file descriptor after calling dup2?

我这辈子都无法完全理解 dup2()

    int fd = open("data", O_RDONLY); 
    /* open the disk file */
    int newfd = dup2(fd,0); 
    /* close 0, dup fd to 0 */
    if( newfd != 0)
    {
        fprintf(stderr,"Could not duplicate fd to 0\n");
        exit(1);
    }
    close(fd);

所以我知道 dup2() 在这种情况下会关闭 0(stdin 的标准键盘输入),然后它会使 stdin 从文件数据中读取,但为什么要 close(fd)?我以为 fd 是 stdin 从现在开始读取的内容?

open 在内核中创建文件描述,返回的文件描述符有点像从用户空间指向它的指针,除非它是一个负值,在这种情况下 open 失败。 dup2 使 0 也指向相同的文件描述(除非您传递了一个负值或除非您没有文件描述符)。如果你的目标是让 0 指向文件描述符,你现在可以去掉旧的 "pointer" 这样你就不会浪费文件描述符(一个进程只能分配有限的数量)。

(另外关闭对文件描述的最后一个引用可能会导致某些需要的操作,例如如果文件是一个不相似的文件则该文件被删除,或者如果您刚刚关闭对相应文件的最后一个引用则管道的读取端接收 EOF写结束。如果你有 "leaked" 个引用(=忘记了 fd 是什么而不关闭它),就不会发生这种情况。