首先,明确一个类型DIR的含义:
#include <dirent.h>
DIR A type representing a directory stream.(指向一个目录的指针)
DIR是在目录项格式头文件dirent.h中定义的,它表示一个目录流类型。
一、opendir - open a directory
SYNOPSIS
#include <sys/types.h>
#include <dirent.h>
DIR *opendir(const char *name);
DESCRIPTION
opendir函数打开一个与给定的目录名name相对应的目录流,并返回一个指向该目录流的指针。打开后,该目录流指向了目录中的第一个目录项。
RETURN VALUE
opendir函数,打开成功,返回指向目录流的指针;打开失败,则返回NULL,并设置相应的错误代码errno。
例如:
DIR *dir = opendir(“/home/bamp/newdir”);
if(NULL != dir){
/**
...
*/
}
二、readdir - read a directory
SYNOPSIS
#include <sys/types.h>
#include <dirent.h>
struct dirent *readdir(DIR *dir);
DESCRIPTION
readdir函数返回一个指向dirent结构体的指针,该结构体代表了由dir指向的目录流中的下一个目录项;如果读到end-of-file或者出现了错误,那么返回NULL。
在Linux系统中,dirent结构体定义如下:
struct dirent {
ino_t d_ino; /* inode number */
off_t d_off; /* offset to the next dirent */
unsigned short d_reclen; /* length of this record */
unsigned char d_type; /* type of file */
char d_name[256]; /* filename */
};
readdir函数返回的值会被后续调用的(针对同一目录流的)readdir函数返回值所覆盖。
RETURN VALUE
readdir函数,成功时返回一个指向dirent结构体的指针;失败时或读到end-of-file时,返回NULL,并且设置相应的错误代码errno。
注:实质相应目录下的文件.
例如:
struct dirent* ptr = NULL;
为通过opendir打开执行目录流的指针
//相关处理操作
}
三、closedir - close a directory
SYNOPSIS
#include <sys/types.h>
#include <dirent.h>
int closedir(DIR *dir);
DESCRIPTION:
closedir函数关闭与指针dir相联系的目录流。关闭后,目录流描述符dir不再可用。
RETURN VALUE
closedir函数,成功时返回0;失败是返回-1,并设置相应的错误代码errno。
四、chdir, fchdir - change working directory
SYNOPSIS
#include <unistd.h>
int chdir(const char *path);
int fchdir(int fd);
DESCRIPTION
chdir函数改变当前工作目录为path指定的目录。
fchdir函数与chdir功能一样,唯一的区别是fchdir所要改变成的工作目录由打开的文件描述符指定。
RETURN VALUE
成功,返回0;失败,返回-1,并设置相应的错误代码errno。
五.可能用到的某些函数
rename函数的使用方法,
rename(更改文件名称或位置)
相关函数
表头文件
定义函数
函数说明
的文件名称。若newpath所指定的文件已存在,则会被删除。
返回值 执行成功则返回0,失败返回-1,错误原因存于errn