DIRFD(3) Руководство программиста Linux DIRFD(3)

ИМЯ

dirfd - получение файлового дескриптора потока каталога

ОБЗОР

#include <sys/types.h> #include <dirent.h>

int dirfd(DIR *dirp);

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

dirfd():

/* начиная с glibc 2.10: */ _POSIX_C_SOURCE >= 200809L || /* в версии glibc <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE

ОПИСАНИЕ

Функция dirfd() возвращает файловый дескриптор, связанный с потоком каталога dirp.

Этот файловый дескриптор используется внутри функции потоком каталога. В результате он полезен только для функций, которые не зависят и не изменяют положение в файле, например fstat(2) и fchdir(2). Он автоматически закрывается при вызове closedir(3).

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении возвращается неотрицательный файловый дескриптор. При ошибке возвращается -1 и errno устанавливается в соответствующее значение.

ОШИБКИ

В POSIX.1-2008 определены две ошибки, ни одна из которых не возвращается текущей реализацией.

Значение dirp не указывает на допустимый поток каталога.
Реализация не поддерживает связь файлового дескриптора с каталогом.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).

Интерфейс Атрибут Значение
dirfd() Безвредность в нитях MT-Safe

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2008. Данная функция была расширением BSD, появилась в 4.3BSD-Reno, не в 4.2BSD.

СМОТРИТЕ ТАКЖЕ

open(2), closedir(3), opendir(3), readdir(3), rewinddir(3), scandir(3), seekdir(3), telldir(3)

2016-03-15 Linux