在 CentOS 系統中,使用 readdir
函數來遍歷目錄時,可以通過遞歸的方式控制搜索的深度。readdir
本身并不直接提供限制搜索深度的功能,但你可以在代碼中實現這個邏輯。以下是一個使用 C 語言編寫的示例,展示如何限制 readdir
的搜索深度:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dirent.h>
#include <sys/stat.h>
// 遞歸遍歷目錄并限制搜索深度
void list_directory(const char *path, int depth, int max_depth) {
if (depth > max_depth) {
return;
}
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[1024];
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("Directory: %s\n", full_path);
list_directory(full_path, depth + 1, max_depth);
} else {
printf("File: %s\n", full_path);
}
}
closedir(dir);
}
int main(int argc, char *argv[]) {
if (argc != 3) {
fprintf(stderr, "Usage: %s <directory> <max_depth>\n", argv[0]);
return EXIT_FAILURE;
}
const char *directory = argv[1];
int max_depth = atoi(argv[2]);
list_directory(directory, 0, max_depth);
return EXIT_SUCCESS;
}
遞歸函數 list_directory
:
path
是當前遍歷的目錄路徑。depth
是當前的深度。max_depth
是允許的最大深度。主函數 main
:
list_directory
函數開始遍歷。使用以下命令編譯和運行程序:
gcc -o list_dir list_dir.c
./list_dir /path/to/directory 2
將 /path/to/directory
替換為你想要遍歷的目錄路徑,將 2
替換為你想要的最大深度。
這個示例代碼會遞歸地遍歷指定目錄及其子目錄,但不會超過指定的最大深度。