Проверка, является ли файл каталогом или просто файлом
Я пишу программу для проверки, является ли что-то файлом или является каталогом. Есть ли лучший способ сделать это, чем это?
#include <stdio.h>
#include <sys/types.h>
#include <dirent.h>
#include <errno.h>
int isFile(const char* name)
{
DIR* directory = opendir(name);
if(directory != NULL)
{
closedir(directory);
return 0;
}
if(errno == ENOTDIR)
{
return 1;
}
return -1;
}
int main(void)
{
const char* file = "./testFile";
const char* directory = "./";
printf("Is %s a file? %s.\n", file,
((isFile(file) == 1) ? "Yes" : "No"));
printf("Is %s a directory? %s.\n", directory,
((isFile(directory) == 0) ? "Yes" : "No"));
return 0;
}
Ответы
Ответ 1
Вы можете вызвать функцию stat() и использовать макрос S_ISREG()
в поле st_mode
stat, чтобы определить, указывает ли ваш путь на обычный файл:
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
int is_regular_file(const char *path)
{
struct stat path_stat;
stat(path, &path_stat);
return S_ISREG(path_stat.st_mode);
}
Обратите внимание, что есть другие типы файлов, кроме обычных и каталогов, таких как устройства, каналы, символические ссылки, сокеты и т.д. Возможно, вы захотите их учесть.
Ответ 2
Используйте макрос S_ISDIR
:
int isDirectory(const char *path) {
struct stat statbuf;
if (stat(path, &statbuf) != 0)
return 0;
return S_ISDIR(statbuf.st_mode);
}
Ответ 3
Да, лучше. Проверьте функцию stat
или fstat
Ответ 4
Обычно вы хотите выполнить эту проверку атомарно с использованием результата, поэтому stat()
бесполезен. Вместо этого open()
файл сначала доступен для чтения и используйте fstat()
. Если это каталог, вы можете использовать fdopendir()
чтобы прочитать его. Или вы можете попробовать открыть его для записи для начала, и open не удастся, если это каталог. Некоторые системы (POSIX 2008, Linux) также имеют расширение O_DIRECTORY
для open
, что делает отказ вызова, если имя не является каталогом.
Ваш метод с opendir()
также хорош, если вам нужен каталог, но вы не должны его закрывать; вы должны пойти и использовать его.