在 Linux 中,opendir
函數用于打開一個目錄流,但本身并不提供遞歸遍歷功能。要實現遞歸目錄遍歷,通常需要結合其他函數如 readdir
、closedir
以及 stat
來檢查每個條目是否為目錄,并在是目錄時遞歸調用遍歷函數。
下面是一個使用 C 語言實現的遞歸目錄遍歷示例:
#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <sys/stat.h>
#include <string.h>
#include <errno.h>
// 遞歸遍歷目錄的函數
void recursive_directory_traversal(const char *path) {
DIR *dir = opendir(path);
if (dir == NULL) {
// 如果無法打開目錄,輸出錯誤信息并返回
perror("opendir");
return;
}
struct dirent *entry;
while ((entry = readdir(dir)) != NULL) {
// 跳過當前目錄和上級目錄的特殊條目
if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0)
continue;
// 構建完整的路徑
char full_path[PATH_MAX];
snprintf(full_path, sizeof(full_path), "%s/%s", path, entry->d_name);
struct stat path_stat;
if (stat(full_path, &path_stat) == -1) {
// 如果無法獲取文件狀態,輸出錯誤信息并繼續
perror("stat");
continue;
}
if (S_ISDIR(path_stat.st_mode)) {
// 如果是目錄,遞歸調用
printf("進入目錄: %s\n", full_path);
recursive_directory_traversal(full_path);
} else {
// 如果是文件,打印文件名
printf("文件: %s\n", full_path);
}
}
closedir(dir);
}
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "用法: %s <目錄路徑>\n", argv[0]);
return EXIT_FAILURE;
}
const char *start_path = argv[1];
printf("開始遍歷目錄: %s\n", start_path);
recursive_directory_traversal(start_path);
printf("遍歷完成。\n");
return EXIT_SUCCESS;
}
包含必要的頭文件:
stdio.h
、stdlib.h
:用于標準輸入輸出和通用工具函數。dirent.h
:用于目錄操作。sys/stat.h
和 string.h
:用于文件狀態檢查和字符串操作。errno.h
:用于錯誤處理。recursive_directory_traversal
函數:
opendir
打開目錄流。readdir
讀取目錄中的每個條目。.
和 ..
這兩個特殊條目。stat
獲取每個條目的文件狀態。closedir
關閉目錄流。main
函數:
recursive_directory_traversal
開始遍歷指定的起始目錄。將上述代碼保存為 recursive_traverse.c
,然后使用以下命令編譯:
gcc -o recursive_traverse recursive_traverse.c
運行程序并指定要遍歷的目錄,例如:
./recursive_traverse /path/to/directory
S_ISLNK
標志來避免這種情況。perror
輸出錯誤信息。根據實際需求,可能需要更復雜的錯誤處理機制。你可以根據需要對代碼進行擴展,例如:
stat
獲取更多文件信息,如大小、修改時間等。希望這個示例能幫助你在 Linux 中實現遞歸目錄遍歷。如果有進一步的問題,歡迎繼續提問!