为什么文件描述符中省略了 20

Why 20 is omitted from the file descriptor

编辑:

lsof 表示由 ptmx 打开。感谢@zwol


我下面的代码打印从打开返回的文件描述符。我注意到 20 不见了。据我所知没有类似的问题。

背景:

代码:

int main()
{
    char name[2] = "a";
    for (int i = 0; i < 52; i++) {
        int fd = open(name, O_RDWR | O_CREAT, 0644);
        printf("fd is %d\n", fd);
    }
    return 0;
}

输出:

$ ./a.out 
fd is 3
fd is 4
fd is 5
...
fd is 18
fd is 19
fd is 21 <-- here
fd is 22
...

lsof

...
a.out   1815 ryan   19u   REG   8,16        0 42321 /tmp/tmp/a
a.out   1815 ryan   20u   CHR    5,2      0t0 15832 /dev/ptmx
a.out   1815 ryan   21u   REG   8,16        0 42321 /tmp/tmp/a
...

我有两个问题:

  1. 背后的原因是什么? (什么触发 ptmx
  2. 如果我一直打开文件,会不会缺少更多的索引? (更多类似 ptmx 的程序?)

POSIX 表示每个分配文件描述符的系统调用都必须使用尚未使用的最小数字。因此,20 号描述符必须已经打开。您的示例程序在循环之前没有打开任何东西,因此它一定是从您的 shell 继承的,或者在 main.

之前由 C 库打开的

你可以通过让你的程序打印它的 PID 然后在循环后长时间休眠,然后在它休眠时 运行 lsof 在它上面找到更多信息。