为什么文件描述符中省略了 20
Why 20 is omitted from the file descriptor
编辑:
lsof
表示由 ptmx
打开。感谢@zwol
我下面的代码打印从打开返回的文件描述符。我注意到 20 不见了。据我所知没有类似的问题。
背景:
- 文件系统:ext4
- Ubuntu WSL2 上的 20.04
代码:
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
...
我有两个问题:
- 背后的原因是什么? (什么触发
ptmx
)
- 如果我一直打开文件,会不会缺少更多的索引? (更多类似
ptmx
的程序?)
POSIX 表示每个分配文件描述符的系统调用都必须使用尚未使用的最小数字。因此,20 号描述符必须已经打开。您的示例程序在循环之前没有打开任何东西,因此它一定是从您的 shell 继承的,或者在 main.
之前由 C 库打开的
你可以通过让你的程序打印它的 PID 然后在循环后长时间休眠,然后在它休眠时 运行 lsof
在它上面找到更多信息。
编辑:
lsof
表示由 ptmx
打开。感谢@zwol
我下面的代码打印从打开返回的文件描述符。我注意到 20 不见了。据我所知没有类似的问题。
背景:
- 文件系统:ext4
- Ubuntu WSL2 上的 20.04
代码:
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
...
我有两个问题:
- 背后的原因是什么? (什么触发
ptmx
) - 如果我一直打开文件,会不会缺少更多的索引? (更多类似
ptmx
的程序?)
POSIX 表示每个分配文件描述符的系统调用都必须使用尚未使用的最小数字。因此,20 号描述符必须已经打开。您的示例程序在循环之前没有打开任何东西,因此它一定是从您的 shell 继承的,或者在 main.
之前由 C 库打开的你可以通过让你的程序打印它的 PID 然后在循环后长时间休眠,然后在它休眠时 运行 lsof
在它上面找到更多信息。