C语言opendir()函数:打开目录函数
头文件:
1
|
#include <sys/types.h> #include <dirent.h> |
定义函数:
1
|
DIR * opendir( const char * name); |
函数说明:opendir()用来打开参数name 指定的目录, 并返回DIR*形态的目录流, 和open()类似, 接下来对目录的读取和搜索都要使用此返回值.
返回值:成功则返回DIR* 型态的目录流, 打开失败则返回NULL.
错误代码:
1、EACCESS 权限不足。
2、EMFILE 已达到进程可同时打开的文件数上限。
3、ENFILE 已达到系统可同时打开的文件数上限。
4、ENOTDIR 参数name 非真正的目录。
5、ENOENT 参数name 指定的目录不存在, 或是参数name 为一空字符串。
6、ENOMEM 核心内存不足。
C语言closedir()函数:关闭目录
头文件:
1
|
#include <sys/types.h> #include <dirent.h> |
定义函数:
1
|
int closedir(DIR *dir); |
函数说明:closedir()关闭参数dir 所指的目录流。
返回值:关闭成功则返回0,,失败返回-1,,错误原因存于errno 中。
错误代码:EBADF 参数dir 为无效的目录流。
范例:参考readir()。
C语言readdir()函数:读取目录函数
头文件:
1
|
#include <sys/types.h> #include <dirent.h> |
定义函数:
1
|
struct dirent * readdir(DIR * dir); |
函数说明:readdir()返回参数dir 目录流的下个目录进入点。结构dirent 定义如下:
1
2
3
4
5
6
7
8
|
struct dirent { ino_t d_ino; //d_ino 此目录进入点的inode ff_t d_off; //d_off 目录文件开头至此目录进入点的位移 signed short int d_reclen; //d_reclen _name 的长度, 不包含NULL 字符 unsigned char d_type; //d_type d_name 所指的文件类型 d_name 文件名 har d_name[256]; }; |
返回值:成功则返回下个目录进入点. 有错误发生或读取到目录文件尾则返回NULL.
附加说明:EBADF 参数dir 为无效的目录流。
范例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
#include <sys/types.h> #include <dirent.h> #include <unistd.h> main() { DIR * dir; struct dirent * ptr; int i; dir = opendir( "/etc/rc.d" ); while ((ptr = readdir(dir)) != NULL) { printf ( "d_name : %s\n" , ptr->d_name); } closedir(dir); } |
执行:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
d_name : . d_name : .. d_name : init.d d_name : rc0.d d_name : rc1.d d_name : rc2.d d_name : rc3.d d_name : rc4.d d_name : rc5.d d_name : rc6.d d_name : rc d_name : rc.local d_name : rc.sysinit |