共计 483 个字符,预计需要花费 2 分钟才能阅读完成。
使用方面考虑,会产生递归黑洞,举例:
文件夹 a,b,在 a 下面创建 b 文件夹得硬链接 c,在 b 下面创建 a 文件夹的硬链接 d,
ls a,会看到 c,ls c,看到 b 下的文件夹 d,再 ls d 又看到 c,这样可以无限 ls 下去
软连接在访问时 readlink 有递归次数的限制,硬链接就是普通 inode,所以没办法记录递归次数
代码实现角度
代码实现方面应该是可以做到的。首先 pwd 不是由文件系统拼接路径的,而是记录在一个全局变量中,所以 cd。。的时候只是需要获得上一级目录 inode 的属性来检查权限,或者显示属性信息。路径只需要简单运算就可以得到。
每个路径都对应一个 dentry,即使是相同的 inode,如果是不同 path,那么 dentry 是不同的,dentry 在内存中的 hashtable 是通过父目录的 dentry 来 hash,而不是父目录 inode,
path_walk 的过程中,如果父目录是软连接,则会 readlink 找到被连接的父目录 inode,再用该 inode 来获取名字空间。
正文完
星哥玩云-微信公众号