本文介紹如何利用Linux系統下的標準C庫函數opendir、readdir和closedir實現目錄的遞歸遍歷。 雖然這些函數本身并不支持遞歸,但我們可以通過編寫遞歸函數來完成此功能。
以下代碼示例演示了如何使用這些函數遞歸遍歷給定目錄:
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <string.h> #include <sys/stat.h> void traverseDirectory(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 fullPath[PATH_MAX]; snprintf(fullPath, sizeof(fullPath), "%s/%s", path, entry->d_name); // 獲取文件/目錄信息 if (stat(fullPath, &path_stat) == -1) { perror("stat"); continue; } // 遞歸處理子目錄 if (S_ISDIR(path_stat.st_mode)) { printf("目錄: %sn", fullPath); traverseDirectory(fullPath); } else { // 打印文件 printf("文件: %sn", fullPath); } } // 關閉目錄 closedir(dir); } int main(int argc, char *argv[]) { if (argc != 2) { fprintf(stderr, "用法: %s <目錄路徑>n", argv[0]); return EXIT_FAILURE; } traverseDirectory(argv[1]); return EXIT_SUCCESS; }
代碼說明:
- 打開目錄: opendir()函數打開指定的目錄。
- 讀取目錄條目: readdir()函數逐個讀取目錄中的條目。
- 跳過特殊條目: 代碼跳過表示當前目錄(“.”)和父目錄(“..”)的條目。
- 構建完整路徑: snprintf()函數構建每個條目的完整路徑。
- 獲取文件/目錄信息: stat()函數獲取文件或目錄的屬性信息,用于判斷是文件還是目錄。
- 遞歸處理: 如果條目是目錄(S_ISDIR()),則遞歸調用traverseDirectory()函數。
- 關閉目錄: closedir()函數關閉打開的目錄。
編譯和運行:
將代碼保存為例如recursive_traversal.c,然后使用以下命令編譯和運行:
gcc -o recursive_traversal recursive_traversal.c ./recursive_traversal /path/to/your/directory
將/path/to/your/directory替換成你想要遍歷的目錄路徑。 程序會遞歸地列出該目錄及其所有子目錄下的文件和目錄。
這個改進后的版本使用了更清晰的變量名和注釋,并對代碼結構進行了微調,使其更易于理解和維護。