fstat, stat и lstat
Системный вызов fstat
возвращает информацию о состоянии файла, ассоциированного с открытым дескриптором файла. Эта информация записывается в структуру buf
, адрес которой передается как параметр.
Далее приведена синтаксическая запись вызовов.
#include
#include
#include
int fstat(int fildes, struct stat *buf);
int stat(const char *path, struct stat *buf);
int lstat(const char *path, struct stat *buf);
Примечание
Учтите, что включение файла sys/types.h не обязательное, но мы рекомендуем включать его при использовании системных вызовов, поскольку некоторые из их определений применяют для стандартных типов псевдонимы, которые могут измениться когда-нибудь.
Родственные функции stat
и lstat
возвращают информацию о состоянии названного файла. Они возвращают те же результаты за исключением того, что файл является символической ссылкой. Вызов lstat
возвращает данные о самой ссылке, а вызов stat
— о файле, на который ссылка указывает.
Элементы вызываемой структуры stat могут меняться в разных UNIX-подобных системах, но обязательно включают перечисленные в табл. 3.4 элементы.
Таблица 3.4
Элемент структуры stat |
Описание |
st_mode |
Права доступа к файлу и сведения о типе файла |
st_ino |
Индекс, ассоциированный с файлом |
st_dev |
Устройство, на котором размещен файл |
st_uid |
Идентификатор (user identity) владельца файла |
st_gid |
Идентификатор группы (group identity) владельца файла |
st_atime |
Время последнего обращения |
st_ctime |
Время последнего изменения прав доступа, владельца, группы или объема |
st_mtime |
Время последней модификации содержимого |
st_nlink |
Количество жестких ссылок на файл |
У флагов st_mode
, возвращаемых в структуре stat
, также есть ряд ассоциированных макросов в заголовочном файле sys/stat.h. В эти макросы включены имена флагов для прав доступа и типов файлов и некоторые маски, помогающие проверять специфические типы и права.
Флаги прав доступа такие же, как в системном вызове open
, описанном ранее. Для флагов типов файла включены следующие имена:
□ S_IFBLK
— блочное устройство;
□ S_IFDIR
— каталог;
□ S_IFCHR
— символьное устройство;
□ S_IFIFO
— FIFO (именованный канал);
□ S_IFREG
— обычный файл;
□ S_IFLNK
— символическая ссылка.
Для других флагов режима файла включены следующие имена:
□ S_ISUID
— элемент получает setUID при выполнении;
□ S_ISGUID
— элемент получает setGID при выполнении.
Для масок, интерпретирующих флаги st_mode
, включены следующие имена:
□ S_IFMT
— тип файла;
□ S_IRWXU
— права пользователя на чтение/запись/выполнение;
□ S_IRWXG
— права группы на чтение/запись/выполнение;
□ S_IRWXO
— права остальных на чтение/запись/выполнение.
Существует ряд макросов, помогающих определить типы файлов. Они просто сравнивают надлежащим образом установленные флаги режима файла с подходящим флагом, типа устройства. К ним относятся следующие:
□ S_ISBLK
— проверка для блочного файла;
□ S_ISCHR
— проверка для символьного файла;
□ S_ISDIR
— проверка для каталога;
□ S_ISFIFO
— проверка для FIFO;
□ S_ISREG
— проверка для обычного файла;
□ S_ISLNK
— проверка для символической ссылки.
Например, для проверки того, что файл не является каталогом и у него есть права на выполнение только для владельца и больше никаких других прав, вы можете воспользоваться следующим тестом;
struct stat statbuf;
mode_t modes;
stat("filename", &statbuf);
modes = statbuf.st_mode;
if (!S_ISDIR(modes) && (modes & S_IRWXU) = S_IXUSR)
...
dup и dup2
Системные вызовы dup
позволяют дублировать дескриптор файла, предоставляя два или несколько разных дескрипторов, обращающихся к одному и тому же файлу. Эта возможность может применяться для чтения и записи в разные части файла. Системный вызов dup
дублирует файловый дескриптор fildes
и возвращает новый дескриптор. Системный вызов dup2
умело копирует один дескриптор файла в другой, задавая дескриптор, применяемый для копии.
Далее приведена синтаксическая запись для вызовов.
#include
Читать дальше