readdir 和 opendir 是在 C 语言中用于处理目录的两个函数,它们通常在 POSIX 兼容的系统(如 Linux)中使用。这两个函数都包含在 <dirent.h> 头文件中,用于遍历目录中的文件和子目录。
opendir 函数用于打开一个目录流,返回一个指向 DIR 类型的指针。这个指针随后可以用于读取目录内容。函数原型如下:
DIR *opendir(const char *name);
如果成功,opendir 返回一个非空的 DIR 指针;如果失败,则返回 NULL。
readdir 函数用于读取由 opendir 打开的目录流中的下一个目录项。函数原型如下:
struct dirent *readdir(DIR *dirp);
这里,dirp 是 opendir 返回的 DIR 指针。readdir 函数返回一个指向 struct dirent 的指针,该结构体包含了目录项的信息,如文件名、inode 号等。如果已经到达目录流的末尾,readdir 返回 NULL。
下面是一个简单的例子,展示了如何使用 opendir 和 readdir 来遍历一个目录:
#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <string.h>
int main() {
DIR *dir;
struct dirent *entry;
dir = opendir("."); // 打开当前目录
if (dir == NULL) {
perror("opendir");
exit(EXIT_FAILURE);
}
while ((entry = readdir(dir)) != NULL) {
printf("%s\n", entry->d_name); // 打印目录项的名称
}
closedir(dir); // 关闭目录流
return 0;
}
在这个例子中,我们首先使用 opendir 打开当前目录(.),然后使用 readdir 循环读取每个目录项,直到没有更多的目录项为止(readdir 返回 NULL)。最后,我们使用 closedir 关闭目录流。
需要注意的是,readdir 返回的 struct dirent 结构体中的 d_name 字段只包含文件或目录的名称,而不是完整路径。如果需要完整路径,你需要将目录名与父目录的路径拼接起来。此外,readdir 可能会在某些情况下返回 NULL 而不是到达目录流的末尾,例如当发生错误时,因此在使用返回值之前应该检查 errno。