VC 目录操作函数
目录
- 1. int _access( const char *path, int mode );
- 2. int _chdir( const char *dirname );
- 3. int _chdrive( int drive );
- 4. int _findclose( long handle );
- 5. long _findfirst( char *filespec, struct _finddata_t *fileinfo );
- 6. int _findnext( long handle, struct _finddata_t *fileinfo );
- 7. char *_getcwd( char *buffer, int maxlen );
- 8. char *_getdcwd( int drive, char *buffer, int maxlen );
- 9. int _getdrive( void );
- 10. unsigned long _getdrives(void);
- 11. int _mkdir( const char *dirname );
- 12. int _rmdir( const char *dirname );
//Author : cppgp //Email : cppgp@163.com //Time : 2007 03 30 //按照字母顺序排列
1 int _access( const char *path, int mode );
- 功 能 : 测定文件/目录存取权限.
- 头文件 : #include <io.h>
- 参 数 : path:文件或者目录 mode:权限设定,其值如下: 00 Existence only 02 Write permission 04 Read permission 06 Read and write permission
- 返回值 : 拥有该权限返回0 没有权限返回-1,且设置errno为如下值 ENOENT 路径/文件不存在 EACCES 没有相应权限
2 int _chdir( const char *dirname );
- 功 能 : 更改当前工作目录.
- 头文件 : #include <direct.h>
- 返回值 : 成功返回0 失败返回-1,且设置errno如下: ENOENT 该路径不存在
3 int _chdrive( int drive );
- 功 能 : 更改当前工作驱动器.
- 头文件 : #include <direct.h>
- 返回值 : 成功返回0 失败返回-1
- 注 释 : 参数说明 drive =1<==> A盘 drive =2<==> B盘 drive =3<==> C盘 如此等等,该函数可以由_chdir代替
4 int _findclose( long handle );
- 功 能 : 关闭搜寻句柄并释放相应资源
- 头文件 : #include <io.h>
- 参 数 : long handle 搜索句柄(通常由紧靠其前的_findfirst()返回,_findfirst()见下) fileinfo 文件信息buffer
- 返回值 : 成功返回0 出错返回-1,且设置errno为如下值 ENOENT 没有更多的符合该泛式的文件
5 long _findfirst( char *filespec, struct _finddata_t *fileinfo );
- 功 能 : 提供与filespec指定入口泛式匹配的第一个文件.通常后继用_findnext函数后续使用来完成某泛式下的文件遍历.
- 头文件 : #include <io.h>
- 参 数 : filespec 目标文件规范,可以包含通配符 fileinfo 文件信息buffer
- 返回值 : 成功返回唯一的搜索句柄 出错返回-1,且设置errno为如下值 ENOENT 该泛式无法匹配 EINVAL 无效文件名
6 int _findnext( long handle, struct _finddata_t *fileinfo );
- 功 能 : 按照前面_findfirst中的泛式规则,查找下一个符合该泛式的文件,并以 此为依据修改fileinfo中的值
- 头文件 : #include <io.h>
- 参 数 : long handle 搜索句柄(通常由紧靠其前的_findfirst()返回) fileinfo 文件信息buffer
- 返回值 : 成功返回0 出错返回-1,且设置errno为如下值 ENOENT 没有更多的符合该泛式的文件
7 char *_getcwd( char *buffer, int maxlen );
- 功 能 : 获得当前工作目录.
- 头文件 : #include <direct.h>
- 返回值 : 成功返回指向buffer的pointer 失败返回NULL,且设置errno为以下三个值之一: ENODEV 无该设备 ENOMEM 内存不够 ERANGE 结果超出范围
- 注 意 : 当第一个参数为 NULL 时,第二个参数 maxlen 长度设置无效,且函数使用malloc分配足够内存,需要将函数返回值传递给free()函数来释放内存. 当第一个参数不为 NULL 时,maxlen 指定长度不够函数返回错,设置errno为ERANGE
8 char *_getdcwd( int drive, char *buffer, int maxlen );
功 能 : 获得指定驱动器的当前工作路径. 头文件 : #include <direct.h> 返回值 : 成功返回指向buffer的pointer 失败返回NULL,且设置errno为以下三个值之一: ENODEV 无该设备 ENOMEM 内存不够 ERANGE 结果超出范围
- 注 意 : 当第一个参数为 NULL 时,该函数设置errno为ERANGE
9 int _getdrive( void );
- 功 能 : 获得当前磁盘驱动器.
- 头文件 : #include <direct.h>
- 返回值 : 返回驱动器值,1<==>A 2<==>B 如此等等;函数不会出错!
10 unsigned long _getdrives(void);
- 功 能 : 获得当前所有驱动器.
- 头文件 : #include <direct.h>
- 返回值 : 各个位代表对应驱动器, bit 0 <==> A bit 1 <==> B bit 2 <==> C … …
- 注:bit x 表示unsigned long的第x位
11 int _mkdir( const char *dirname );
- 功 能 : 创建一个新目录,目录名为dirname.
- 头文件 : #include <direct.h>
- 返回值 : 成功返回0 失败返回-1,且设置errno为以下三个值之一 EACCESS 权限不允许 EEXIST 该目录已存在 ENOENT 无该文件或目录
12 int _rmdir( const char *dirname );
- 功 能 : 删除名为dirname的目录.
- 头文件 : #include <direct.h>
- 返回值 : 成功返回0 失败返回-1,且设置errno为以下三个值之一 EACCESS 权限不允许 ENOTEMPTY dirname不是文件夹; 或者该文件夹不空; 或者dirname为当前工作文件夹; 或者dirname为当根文件夹; ENOENT 无该文件或目录
//–end–
//如有错误,希望指出!
//联系 : cppgp@163.com