在 Linux 中,copendir
函數本身并不提供遞歸遍歷目錄的功能。copendir
用于打開一個目錄流,以便后續使用 readdir
等函數讀取目錄內容。要實現遞歸遍歷目錄,通常需要結合使用 opendir
、readdir
和 closedir
函數,并在遇到子目錄時遞歸調用遍歷函數。
以下是一個使用 C 語言實現的遞歸遍歷目錄的示例代碼:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dirent.h>
#include <sys/stat.h>
// 遞歸遍歷目錄的函數
void recursive_directory_traversal(const char *path) {
DIR *dir;
struct dirent *entry;
struct stat path_stat;
// 打開當前目錄
dir = opendir(path);
if (dir == NULL) {
perror("opendir");
return;
}
// 遍歷目錄中的每一項
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);
// 獲取文件/目錄的信息
if (stat(full_path, &path_stat) == -1) {
perror("stat");
continue;
}
// 如果是目錄,則遞歸遍歷
if (S_ISDIR(path_stat.st_mode)) {
printf("Directory: %s\n", full_path);
recursive_directory_traversal(full_path);
} else {
// 如果是文件,則打印文件名
printf("File: %s\n", full_path);
}
}
// 關閉目錄流
closedir(dir);
}
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "Usage: %s <directory>\n", argv[0]);
return EXIT_FAILURE;
}
// 開始遞歸遍歷
printf("Starting recursive directory traversal from: %s\n", argv[1]);
recursive_directory_traversal(argv[1]);
return EXIT_SUCCESS;
}
打開目錄:
opendir
函數打開指定路徑的目錄。如果打開失敗,輸出錯誤信息并返回。讀取目錄項:
readdir
函數逐個讀取目錄中的條目。"."
和 ".."
這兩個特殊條目,避免遞歸到上級目錄。獲取文件/目錄信息:
stat
函數獲取每個條目的詳細信息,包括是否為目錄。遞歸遍歷子目錄:
S_ISDIR
判斷),則打印目錄名并遞歸調用 recursive_directory_traversal
函數。關閉目錄流:
closedir
函數關閉目錄流,釋放資源。主函數:
將上述代碼保存為 recursive_traverse.c
,然后使用以下命令編譯和運行:
gcc -o recursive_traverse recursive_traverse.c
./recursive_traverse /path/to/start/directory
lstat
和檢查 S_ISLNK
來處理符號鏈接,避免重復遍歷。snprintf
構建路徑時,確保緩沖區足夠大以避免溢出。PATH_MAX
通常定義了路徑的最大長度,但在某些系統上可能需要使用其他方法處理長路徑。通過上述方法,可以實現一個基本的遞歸目錄遍歷功能。根據具體需求,還可以擴展功能,例如處理隱藏文件、過濾特定類型的文件、統計文件數量等。