READDIR_R(3) Linux Programmer's Manual READDIR_R(3)

名前

readdir_r - ディレクトリを読み込む

書式

#include <dirent.h>
int readdir_r(DIR *dirp, struct dirent *entry, struct dirent **result);

glibc 向けの機能検査マクロの要件 (feature_test_macros(7) 参照):

readdir_r():

_POSIX_C_SOURCE
|| /* glibc 2.19 以前: */ _BSD_SOURCE || _SVID_SOURCE

説明

この関数は非推奨である。代わりに readdir(3) を使用すること。

readdir_r() 関数は readdir(3) のリエントラント版として導入された。この関数はディレクトリストリーム dirp から次のディレクトリエントリーを読み込み、 entry が指す呼び出し元が割り当てたバッファーにそのエントリーを格納して返す。 dirent 構造体の詳細は readdir(3) を参照。

結果を返すバッファへのポインターが *result に格納される。ディレクトリストリームの末尾に達した場合は、NULL が代わりに *result で返される。

アプリケーションでは readdir_r() の代わりに readdir(3) を使用することを推奨する。さらに、glibc 2.24 以降では readdir_r() は非推奨となっている。理由は以下の通りである。

返り値

成功すると、 readdir_r() 関数は 0 を返す。 エラーの場合、(「エラー」の節のリストに載っている) 正のエラー番号を返す。 ディレクトリストリームの末尾に達した場合、 readdir_r() は返り値として 0 を返し、 *result に NULL を格納する。

エラー

ディレクトリストリームディスクリプター dirp が無効である。
読み込むには名前が長過ぎるディレクトリエントリーに遭遇した。

属性

この節で使用されている用語の説明については、 attributes(7) を参照。

インターフェース 属性
readdir_r() Thread safety MT-Safe

準拠

POSIX.1-2001, POSIX.1-2008.

関連項目

readdir(3)

この文書について

この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。

2016-03-01