1.mkdir函数
使用mkdir函数创建目录。
#include <sys/stat.h>
int mkdir(const char* pathname, mode_t mode);
如果成功返回0,失败返回-1.
此函数创建一个新的空目录,其中.和..目录是自动创建的,所指定的访问权限由mode指定。目录至少设置一个执行权限。
实践:
#include <stdio.h>
#include <fcntl.h>
#include <sys/stat.h>
int main(void){
if(mkdir("mkdirtest",S_IRUSR|S_IWUSR|S_IXUSR)<0){
perror("mkdir");
return -1;
}
return 0;
}
运行结果:
yan@yan-vm:~/apue$./a.out
yan@yan-vm:~/apue$ ll
drwxrwxr-x 4 yan yan 4096 Jul 10 13:25 ./
drwx---rwx 25 yan yan 4096 Jul 10 13:25 ../
drwx------ 2 yan yan 4096 Jul 10 13:25 mkdirtest/
2.rmkdir函数
使用rmdir函数可以删除一个空目录,空目录只包含.和..这两项目录。
#include <unistd.h>
int rmdir(const char* pathname);
如果成功则返回0,如果出错返回-1.
实践:
#include <stdio.h>
#include <unistd.h>
int main(void){
if(rmdir("mkdirtest")<0){
perror("rmdir");
return -1;
}
return 0;
}
运行结果:
yan@yan-vm:~/apue$ ll mkdirtest/
total 8
drwxrwxr-x 2 yan yan 4096 Jul 10 13:37 ./
drwxrwxr-x 4 yan yan 4096 Jul 10 13:37 ../
yan@yan-vm:~/apue$ ./a.out
yan@yan-vm:~/apue$ ll mkdirtest
ls: cannot access mkdirtest: No such file or directory
如果目录内容不为空,会怎么样?
yan@yan-vm:~/apue$ ll mkdirtest/
total 8
drwxrwxr-x 2 yan yan 4096 Jul 10 13:38 ./
drwxrwxr-x 4 yan yan 4096 Jul 10 13:38 ../
-rw-rw-r-- 1 yan yan 0 Jul 10 13:38 a
yan@yan-vm:~/apue$ ./a.out
rmdir: Directory not empty
删除会出错。
3.读取目录信息
通过以下函数可以读取目录的信息。
#include <dirent.h>
DIR *opendir(const char* pathname); //如果成功返回指针,出错则返回NULL。
struct dirent* readdir(DIR* dp); //如果成功返回指针,若在目录结果或者出错则返回NULL。
void rewinddir(DIR* dp); //用来设置参数dir 目录流目前的读取位置为原来开头的读取位置。
int closedir(DIR* dp); //如果成功则返回0,出错则返回-1。
long telldir(DIR* dp); //返回dp关联的目录中的当前位置。
void seekdir(DIR* dp, long loc); //用来设置参数dir目录流目前的读取位置。
其中dirent的结构如下:
struct dirent{
int_t d_ino; //i_node number;
char d_name[NAME_MAX+1];
}
#include <stdio.h>
#include <dirent.h>
int main(int argc, char* argv[]){
int result = 0;
DIR* dir = NULL;
struct dirent* ptr;
if(argc != 2){
printf("parameter error.\n");
result = -1;
goto FINALLY;
}
if((dir = opendir(argv[1])) == NULL){
perror("opendir");
result = -1;
goto FINALLY;
}
while((ptr = readdir(dir)) != NULL){
printf("d_name:%s\n",ptr->d_name);
}
rewinddir(dir);
printf("readdir again.\n");
while((ptr = readdir(dir)) != NULL){
printf("d_name:%s\n",ptr->d_name);
}
FINALLY:
if(dir != NULL){
closedir(dir);
}
return result;
}
运行结果:
yan@yan-vm:~/apue$ ll dirtest/
total 8
drwxrwxr-x 2 yan yan 4096 Jul 10 14:00 ./
drwxrwxr-x 4 yan yan 4096 Jul 10 14:22 ../
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 12345
-rw-rw-r-- 1 yan yan 0 Jul 10 14:00 67890
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 abc
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 def
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 ghi
yan@yan-vm:~/apue$ ./a.out dirtest/
d_name:..
d_name:ghi
d_name:abc
d_name:12345
d_name:def
d_name:67890
d_name:.
readdir again.
d_name:..
d_name:ghi
d_name:abc
d_name:12345
d_name:def
d_name:67890
d_name:.
#include <stdio.h>
#include <dirent.h>
int main(int argc, char* argv[]){
int result = 0;
DIR* dir = NULL;
struct dirent* ptr;
int offset;
if(argc != 2){
printf("parameter error.\n");
result = -1;
goto FINALLY;
}
if((dir = opendir(argv[1])) == NULL){
perror("opendir");
result = -1;
goto FINALLY;
}
offset = telldir(dir);
while((ptr = readdir(dir)) != NULL){
printf("d_name:%s\n",ptr->d_name);
}
seekdir(dir, offset);
printf("readdir again.\n");
while((ptr = readdir(dir)) != NULL){
printf("d_name:%s\n",ptr->d_name);
}
FINALLY:
if(dir != NULL){
closedir(dir);
}
return result;
}
运行结果:
yan@yan-vm:~/apue$ ll dirtest/
total 8
drwxrwxr-x 2 yan yan 4096 Jul 10 14:00 ./
drwxrwxr-x 4 yan yan 4096 Jul 10 14:25 ../
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 12345
-rw-rw-r-- 1 yan yan 0 Jul 10 14:00 67890
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 abc
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 def
-rw-rw-r-- 1 yan yan 0 Jul 10 13:59 ghi
yan@yan-vm:~/apue$ ./a.out dirtest/
d_name:..
d_name:ghi
d_name:abc
d_name:12345
d_name:def
d_name:67890
d_name:.
readdir again.
d_name:..
d_name:ghi
d_name:abc
d_name:12345
d_name:def
d_name:67890
d_name:.
4.chdir、fchdir和getcwd函数
#include <unistd.h>
int chdir(const char* pathname);
int fchdir(int filedes);
使用getcwd函数获取进程当前工作目录的绝对路径。
#include <unistd.h>
char* getcwd(char* buf, size_t size);
如果成功返回buf,失败则返回NULL。
实践:
#include <stdio.h>
#include <unistd.h>
int main(void){
char path[256];
printf("path:%s\n",getcwd(path,256));
if(chdir("/tmp") < 0){
perror("chdir");
return -1;
}
printf("path:%s\n",getcwd(path,256));
return 0;
}
运行结果:
yan@yan-vm:~/apue$ pwd
/home/yan/apue
yan@yan-vm:~/apue$ ./a.out
path:/home/yan/apue
path:/tmp
yan@yan-vm:~/apue$ pwd
/home/yan/apue
可见,执行程序后,shell的当前目录没有改变,其原因是shell创建一个子进程,由该子进程具体执行程序,由此可见,为了改变
shell进程自己的目录,shell应该直接调用chdir,所以cd命令是直接包含在shell程序中的。