在Linux中,readdir函数用于读取目录中的文件和子目录
首先,确保你已经包含了必要的头文件:
#include <dirent.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
接下来,定义一个结构体来存储文件名和文件类型:
typedef struct {
char name[256];
int is_directory;
} FileInfo;
然后,编写一个比较函数,用于qsort函数对文件进行排序:
int compare(const void *a, const void *b) {
FileInfo *file_a = (FileInfo *)a;
FileInfo *file_b = (FileInfo *)b;
return strcmp(file_a->name, file_b->name);
}
现在,编写一个函数来读取目录并填充FileInfo结构体数组:
int read_directory(const char *path, FileInfo *files, int max_files) {
DIR *dir = opendir(path);
if (!dir) {
perror("opendir");
return -1;
}
struct dirent *entry;
int count = 0;
while ((entry = readdir(dir)) != NULL && count < max_files) {
if (entry->d_type == DT_REG || entry->d_type == DT_DIR) {
strncpy(files[count].name, entry->d_name, sizeof(files[count].name));
files[count].is_directory = (entry->d_type == DT_DIR);
count++;
}
}
closedir(dir);
return count;
}
最后,在main函数中调用这些函数并使用qsort对文件进行排序:
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "Usage: %s <directory_path>\n", argv[0]);
return 1;
}
const char *path = argv[1];
FileInfo files[1024];
int file_count = read_directory(path, files, sizeof(files) / sizeof(files[0]));
if (file_count == -1) {
return 1;
}
qsort(files, file_count, sizeof(files[0]), compare);
for (int i = 0; i < file_count; i++) {
printf("%s%s\n", files[i].is_directory ? " [DIR] " : " [FILE] ", files[i].name);
}
return 0;
}
编译并运行这个程序,它将读取指定目录中的文件和子目录,并按字母顺序输出它们。注意,这个程序仅适用于Linux系统。