《APUE》第四章笔记(4)

时间:2024-12-18 08:07:25

这算是在博客园写的第一篇文章啊,之前都在****写(虽然才写了几篇,因为开通也没多少天。。),还是稍微期待下吧。我写博客的主要意图是一来能够记录下来自己所学过的东西,二来也想能够跟大家交流,能够得到更多的意见,来使自己进步。我现在是个大学生,学到的东西还真没多少,所以写出来的东西没营养望能理解。

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

创建硬链接和解除硬链接的函数

link和unlink函数:

#include <unistd.h>

int link(const char *existingpath, const char *newpath);

返回值:成功返回0,出错返回-1

此函数创建一个新的目录项newpath,它引用现有的文件existingpath。若newpath已经存在,则返回出错。只创建newpath中的最后一个分量,路径中的其他部分应当已经存在。

只有超级用户才支持创建一个指向目录的硬链接,因为有可能创建不当的话会引起循环,然后崩溃(第一版的作者试过,文件系统就崩溃了)。因此很多文件系统实现不允许对于目录的硬链接。(我刚刚在自己的Linux系统上试过,真的是不能够对目录来进行硬链接)

为了删除对一个现有的目录项,可以调用unlink函数。

#include <unistd.h>

int unlink(const char *pathname);

返回值:成功返回0,出错返回-1

此函数删除目录项,并将由pathname所引用的文件的链接计数减1.如果出错,则不对该文件做任何修改。

为了解除对文件的链接,必须对包含该目录项的目录具有写和执行的权限。

符号链接

符号链接跟硬链接最大的区别就是修改了硬链接,其文件内容会改变。而符号链接只是个指向一个文件的间接指针。符号链接这种文件类型保存的仅仅是文件名。当使用以文件名作为参数的函数时,应当了解函数是否能处理符号链接。也就是该函数能否跟随符号链接到达它所链接的文件。下面列出了本章所说明的各个函数能否处理符号链接。

《APUE》第四章笔记(4)

symlink和readlink函数

symlink函数创建了一个符号链接。

#include <uinstd.h>

int symlink(const char *actualpath, const char *sympath);

返回值:成功返回0,出错返回-1

创建符号链接时,并不要求actualpath已经存在,而且两个参数也并不需要在同一个文件系统汇中(硬链接要)。

因为open函数跟随符号链接,所以需要一种方法来打开链接本身,并读链接中的名字。readlink函数提供了这种功能。

#include <unistd.h>

ssize_t readlink(const char *pathname, char *buf, size_t bufsize);

返回值:成功返回读到的字节数,出错返回-1

此函数组合了open、read、和close的所有操作。如果此函数执行成功,则它返回读入buf的字节数。在buf中返回的符号链接的内容不以NULL字符终止。

文件的时间

《APUE》第四章笔记(4)

前两个是对于文件的内容的,第三个是对于文件的状态的,即有关i节点的。

目录是包含目录项(文件名和相关i节点编号)的文件,增加、删除和修改目录项会影响到与其所在目录相关的三个时间。下面给出各种函数对时间的作用:

《APUE》第四章笔记(4)

用mkdir函数创建目录,用rmdir函数删除目录

#include <sys/stat.h>

int mkdir(const char *pathname, mode_t mode);

返回值,成功返回0,出错返回-1

其中,dot和dot dot是自动创建的,所指定的文件访问权限mode由进程的文件模式创建屏蔽字修改。

用rmdir函数可以删除一个空目录。空目录是只包含dot和dot dot这两项的目录。

#include <unistd.h>

int rmdir(const char *pathname);

返回值:成功返回0,出错返回-1