本文讨论在操作系统中,文件的逻辑结构与物理结构的区分和联系,如果对文件的逻辑结构和物理结构的详解不清楚,请先去往本人博客学习: 文件的逻辑结构,文件的物理结构
每个字符1B。在用户看来,整个文件占用一片连续的逻辑地址空间。
Eg:你要找到第16个字符(编号从0开始)
被操作系统拆分为若干个块,逻辑块号相邻。
例如:用户使用c语言库函数fgetc,从读写指针所指位置读出1B内容。
只需要指明逻辑地址。
fgetc底层使用了Read系统调用,
操作系统将(逻辑块号,块内偏移量)转换为(物理块号,块内偏移量)。
逻辑上相邻的块物理上也相邻。
逻辑上相邻的块在物理上用链接指针表示先后关系。
操作系统为每个文件维护一张索引表,其中记录了逻辑块号→物理块号的映射关系。
顺序文件:各个记录可以顺序存储或链式存储(用户角度)。
支持随机访问:指可以直接确定第i条记录的逻辑地址。
保存学生信息:
读取第五个学生的记录:
用户用逻辑地址访问文件。
修改学生个人信息的结构体:
索引文件:从用户视角来看,整个文件依然是连续存放的。
如:前1MB存放索引项,后续部分存放记录。
用户自己建立的,映射:关键字→记录存放的逻辑地址.
操作系统建立的,映射:逻辑块号→物理块号.