UNIX系统文件系统与杂项例程解析
一、文件系统相关操作
在文件系统操作中,某些程序与之前示例有相似之处,但也存在一些差异。例如,在 getsblock 例程里,超级块的读取使用 bread 函数,而非直接读取。这是因为超级块的位置定义为磁盘块号,而非字节地址。在 getinodes 例程中, itod 宏返回的是文件系统块号,需通过 fsbtodb 宏将其转换为磁盘块号。要知道,文件系统块可以是4096字节的任意倍数,而磁盘块通常是512字节。并且,调用 bread 函数时使用超级块结构的 fs_bsize 元素,而非定义的常量块大小,因为同一机器上不同文件系统的块大小可能不同。另外,在 bread 函数中,使用 dtob 宏将磁盘块号转换为字节偏移量,而非直接使用移位操作。
1. 从文件系统读取数据块
多数情况下,磁盘上i - 节点结构中存储的信息足以完成任务。不过,有时需要读取文件本身的数据块,像Berkeley系统上的 dump 程序,会读取磁盘上每个文件的数据块,以便将文件备份到磁带上。
文件相关数据块的地址存储在该文件的 dinode 结构中。前几个地址是磁盘上块的直接地址,可将这些地址传递给 bread 函数来读取。下一个地址是单间接块的地址,使用时先读取该块,再将其视为直接块地址数组。双
超级会员免费看
订阅专栏 解锁全文
69

被折叠的 条评论
为什么被折叠?



