在父进程和子进程中关闭目录流 (DIR *) 是否安全?

在父进程和子进程中关闭目录流 (DIR *) 是否安全?

这一页描述了函数的保证行为readdir并且readdir_r包含以下句子:

调用 fork() 后,父级或子级(但不是两者)都可以使用 readdir()、rewinddir() 或eekdir() 继续处理目录流。如果父进程和子进程都使用这些函数,则结果是未定义的。

我正在围绕相关的函数系列编写一个分叉安全包装器DIR*作为练习,我想知道closedir同时对父级和子级中的目录流是否安全,或者该进程是否安全继续从目录流读取根本不应该与目录流交互。

答案1

作为一般性评论,我建议参考目前的描述readdir(这里不会改变任何东西)。

closedir在实践中做了两件事:它释放 C 库分配的内存以跟踪目录流,并且如果opendir//系列函数是使用文件描述符实现的,readdirclosedir它关闭文件描述符。这两个操作都适用于调用它们的进程,而不是潜在的父进程或子进程fork:释放目录流只会影响调用进程的内存(如有必要,创建相关页面的副本以独立于任何进程对它们进行更改)具有来自写时复制的共享内存映射的其他进程fork),并且关闭文件描述符仅影响当前进程(如果另一个进程具有共享底层文件描述的文件描述符,则不会释放文件描述)。

因此,虽然readdir从共享目录流上的不同进程调用不安全(由于底层共享文件描述),但closedir它是安全的。

相关内容