【操作系统】第七、八章 文件与磁盘空间管理

一、文件、文件系统
1、文件逻辑结构的类型
(1)有结构文件(记录式)
①定长记录 (更适合顺序文件)
②变长记录(更适合索引文件)
如何组织记录:
顺序文件。系统需按该类型记录“长度”,通常定长。
索引文件。系统需为文件建立索引表。
索引顺序文件。建索引表,记录每组记录的第一个记录位置。(较大文件可以组织成索引顺序文件)
(2)无结构文件(字符流式)
字节为单位,利用读写指针依次访问。
系统对该类文件不需格式处理。
2.顺序文件
(1)两种记录排列方式
串结构:按记录形成的时间顺序串行排序。记录顺序与关键字无关;
顺序结构:按关键字排序。
(2)具体的寻址过程:
第i条记录地址(定长) :
读写指针 + 记录长度: ptr + i*L
第i条记录地址(变长) :
扫描或读取前面0~i-1条记录
第i条记录地址(变长)
3.索引文件
为了方便单个记录的随机存取,为文件建立一个索引表,记录每项记录在文件的逻辑地址及记录长度;该索引表按关键字排序
(1)索引表内容:
索引号、长度、记录地址指针
(2)一个索引文件可以有多个索引表
为方便用户根据不同记录属性检索记录,为顺序文件建立多个索引表,每种能成为检索条件的域都配备一张索引表。
(3)索引文件的优缺点
适用于变长记录,可提高检索速度,实现直接存取
索引表增加了存储开销
4.索引顺序文件
(1)
将顺序文件的所有记录分组
还是建立索引表,但每个表项记录的是每组第1条记录的键值和地址。
组内记录仍按顺序方式检索和使用。
(2)检索一条记录的过程:
先计算记录是在第几组,然后再检索索引确定组在哪里后,在组内顺序查找。
5.直接文件
给定键值(如学号)不需顺序检索直接得到记录的物理地址(HASH函数)
6.外存分配方式
(1)常用三种方式:
连续分配
链接分配(不连续)
索引分配
(2)采用的磁盘分配方式决定了文件的“物理结构”
顺序结构;链接式结构;索引式结构。
(3)
a.连续分配 会产生外存碎片
为每一个文件分配一组相邻的盘块。
逻辑文件中的记录顺序与存储器中文件占用盘块的顺序一致。
directory
file(文件名) start(开始) length(长度)
count 0 2

b.链接分配
可以为每一个文件分配一组不相邻的盘块。
设置链接指针,将同属于一个文件的多个离散盘块链接成一个链表,这样形成的文件称为链接文件。会有链接成本。
1)隐式链接
链接信息隐含记录在盘块数据中;
每个盘块拿出若干字节,记录指向下一盘块号的指针。
directory
file(文件名) start(开始) end(结束)
jeep 9 25
2)隐式链接
记录盘块链接的指针显示地记录为一张链接表
所有已分配的盘块号都记录在其中,称文件分配表
为了提高文件系统访问速度,FAT一般常驻内存
c.索引分配
系统运行时只涉及部分文件,FAT表无需全部调入内存
每个文件单独建索引表(物理盘块索引),记录所有分配给它的盘块号;
建立文件时,便分配一定的外存空间用于存放文件盘块索引表信息;
1)单级索引分配(适合大文件)
2)多级索引
若文件较大,存放索引表也需要多个盘块(索引盘块)。
索引盘块亦需要按顺序管理起来
若索引盘块数量较少用指针链接的方式即可;
若索引盘块较多,需对索引盘块也采用索引方式管理,形成多级索引。
7.存储空间的管理
为实现存储空间分配,系统需要:
记住空闲存储空间使用情况;为空间设置相应的数据结构;
提供对存储空间分配、回收的操作手段。
典型的管理方法:
1)空闲表和空闲链表法
a.空闲表法
常用于连续分配管理方式
数据结构
系统为外存上的所有空闲区建立一张空闲表
每个空闲区对应一个空闲表项
(表项包括序号、空闲区的第一个盘块号、空闲盘块数等。)
将所有空闲区按其起始盘块号递增的次序排列,
b.空闲链表法
将所有空闲盘区拉成一条空闲链。
数据结构:链
根据构成链所用基本元素的不同,可把链表分成两种形式:
空闲盘块链
空闲盘区链
2)位示图法
利用二进制的一位来表示一个盘块的使用情况。
值为0表示对应的盘块空闲,为1表示已分配。有的系统则相反。
磁盘上的所有盘块都有一个二进制位与之对应,这样由所有盘块所对应的位构成一个集合,称为位示图。
3)成组链接法
中心思想:
所有盘块按规定大小划分为组;
组间建立链接;
组内的盘块借助一个系统栈可快速处理,且支持离散分配回收。
二、目录管理
1.文件控制块—FCB(用于描述和控制文件的数据结构)
(1)文件与文件控制块一一对应
把文件控制块的有序集合称为文件目录,即一个文件控制块就是一个目录项。通常一个文件目录也被看作是一个文件,称为目录文件。
(2)在文件控制块中,通常含有以下三类信息:
基本信息类:包括文件名,文件物理位置,文件逻辑结构,文件的物理结构。
对于连续文件:文件起始块号;
对于链接文件:指向第一个物理块的指针;
对于索引文件:索引表地址。
存取控制信息类:包括文件主的存取权限,核准用户的存取权限和一般用户的存取权限。
使用信息类
2.目录结构
(1)目前常用的目录结构形式有
单级目录
两级目录
多级目录
(2)单级目录结构
整个文件系统中只建立一张目录表,每个文件一个目录项,含有文件相关信息。
每建立一个新文件:
先检索所有的目录项,保证文件名唯一。
获得一空白目录项,填入相关信息,修改状态位(表明每个目录项是否空闲)。
(3)两级目录结构
为每一个用户建立一个单独的用户文件目录UFD,UFD由用户所有文件的文件控制块组成。
系统建立一个主文件目录MFD, MFD中每个用户目录文件都占有一个目录项,其中包括用户名和指向UFD的指针。
(4)多级目录结构
适用于较大的文件系统管理。又称为树状目录
3.目录查询技术
用户要访问一个已存文件
目录数据调入内存;
按名检索:系统利用提供的文件名对目录(根据目录层次,需要做的检索次数也不同)进行查询
找该文件控制块
读FCB或对应索引结点;
从文件物理地址换算出文件在磁盘上的物理位置;
最后通过磁盘驱动程序,将所需文件读入内存。
目录查询方式:线性检索法和Hash方法
4.线性检索法
单级目录中
用户提供文件名,顺序查找文件目录
5.文件共享与保护
1)文件共享
多个用户共享一份文件,只保留文件的一份副本,节约存储空间
a.索引结点
基本FCB法:
名+详细信息。
直接在文件目录中包含文件的物理地址,该方法实现的共享不适用文件动态变化。一个用户对文件的修改(如物理块号增加),对其他用户不可见,共享文件的FCB信息记录同步更新困难。
文件名+索引结点指针。
一个用户修改指针指向地址里的内容,指针不变,其他用户通过指针总能感知索引结点中的最新内容
索引结点中增加count计数
b.符号链
创建一个link类型的文件:“文件名+共享文件路径”(类似快捷方式)
文件主人删除文件,共享者只会出现找不到文件错误。不会发生共享文件删除后出现悬空指针的情况。
该方法适用于网络文件共享,但根据路径检索共享文件的目标位置增加了访问开销,link文件独占索引结点也耗费一定的空间。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值