第28讲 文件管理之文件存储空间管理

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第二十八讲文件管理之文件存储空间管理

文件存储空间的管理,就是空闲空间的管理。下面介绍几个常用的管理方法:

1 空闲表法和空闲链表法

1.1 空闲表法

空闲表:系统为空闲区建立一张空闲表,每个空闲区对应于一个空闲表项,其中包括表项序

号、该空闲区的第一个盘块号、该区的空闲盘块数等信息。再将所有空闲区按其起始盘块号递增的次序排列,

如下图。

存储空间的分配和回收:

➢与内存的动态分配类似,同样是采用首次适应算法、循环首次适应算法等。

➢内存管理中虽然很少采用连续分配方式,然而在外存的管理中,由于它具有较高的分配速度,可减少访问磁盘的I/O频率,故仍可采用连续分配算法。

1.2 空闲链表法

空闲链表法是将所有空闲盘区拉成一条空闲链。根据构成链所用基本元素的不同,可把链表分成两种形式:

1.空闲盘块链:将磁盘上的所有空闲空间,以盘块为单位拉成一条链。

分配存储空间时,系统从链首开始,依次摘下适当数目的空闲盘块分配给用户。

释放存储空间时,系统将回收的盘块依次插入空闲盘块链的末尾。

优点:是用于分配和回收一个盘块的过程非常简单

缺点:是分配盘块时,可能要重复操作多次

2.空闲盘区链:将磁盘上的所有空闲盘区(每个盘区可包含若干盘块)拉成一条链。

➢在每个盘区上除含有用于指示下一个空闲盘区的指针外,还应有能指明本盘区大小的信息。

➢分配盘区的方法与内存动态分区分配类似,通常采用首次适应算法。

➢在回收盘区时,同样也要将回收区与相邻的空闲盘区相合并。

➢在采用首次适应算法时,为提高对空闲盘区的检索速度,可以采用显式链接方法,亦即,在内存中为空闲盘区建立一张链表。

2 位示图法

2.1 什么是位示图?

位示图是利用二进制的一位来表示磁盘中一个盘块的使用情况。0表示盘块空闲,1表示已

分配。磁盘上所有盘块所对应的位构成一个集合,称为位示图。通常可用m*n个位数来构成位示图,并使m*n等于磁盘的总块数。

如下图。可看成是二维数组。

2.2 盘块的分配

根据位示图进行盘块分配时,可分三步进行:

1)顺序扫描位示图。找到0二进制位。

2)将所找到的一个或一组二进制位,转换成与之对应的盘块号。

盘块号=列数*(i-1)+j;(i,j,b(盘块号)都从1开始)

盘块号=列数*i+j+1; (i,j从0开始,b从1开始)

3)修改位示图。令map[I,j]=1

i,j,b(盘块号)都从1开始。

2.3 盘块的回收

盘块的回收分两步:

1)将回收盘块的盘块号转换成位示图中的行号和列号。转换公式为

(i,j,b(盘块号)都从1开始):

i=(盘块号-1)\列数+1

j=(盘块号-1)mod列数+1

i,j从0开始,b从1开始:

i=(盘块号-1)\列数

j=(盘块号-1)mod列数

2)修改位示图。令map[I,j]=0

公式中减1加1的目的是凑齐最后一列的得数!

优点是从位示图中很容易找到一个或一组相邻接的空闲盘块。常用于微型机和小型机中。

3 成组链接法

3.1引入

空闲表法和空闲链表法都不适用于大型文件系统,因为这会使空闲表或空闲链表太长。

在UNIX系统中采用的是成组链接法

是将上述两种方法结合而形成的一种空闲盘块管理方法,它兼备了上述方法的优点而克服了表太长的缺点。

3.2 空闲盘块的组织

➢空闲盘块号栈。用来存放当前可用的一组空闲盘块的盘块号(最多含100个号),以及栈中尚有的空闲盘块号数N。引入一个数据结构,栈

➢N还兼作栈顶指针。例如当N=100时,它指向S.free(99)。S.free(0)是栈底,栈满时栈顶为S.free(99)。实际上就是利用N-1来做下标。

➢文件中的所有空闲盘块,被分成若干个组,如有100000个盘块,每100块为1组,将会分成1000个组。

➢将每一组含有的盘块总数N和该组的盘块号,记入其前一组的第一个盘块的S.free(0)~S.free(99)中。这样由各组的第一个盘块形成了一条链。

➢将第一组的盘块总数和所有的盘块号,记入空闲盘块号栈中,作为当前可供分配的空闲盘块号。

➢最末一组只有99个盘块,其盘块号分别记入其前一组的S.free(1)~S.free(99)中,而在S.free(0)中则存放0,作为空闲盘块链的结束标志。

空闲盘块的成组链接法示意图

3.3 空闲盘块的分配

➢首先检查空闲盘块号栈是否上锁,如没有,便从栈顶取出一空闲盘块号,将与之对应的盘块分配给用户,然后将栈顶指针下移一格

➢若该盘块号已是栈底,即S.free(0),这是当前栈中最后一个可供分配的盘块号。由于在该盘块号所对应的盘块中即有下一组可用的盘块号,因此须调用磁盘读过程,

将该盘块内容读入栈中,作为盘块号栈的新内容,并把原栈底盘块分配出去。

3.4 空闲盘块的回收

➢将回收盘块的盘块号记入空闲盘块号栈的顶部,并执行空闲盘块号加1操作。

➢当栈中空闲盘块号数目已达100时,表示栈已满,便将现有栈中的100个盘块号,记入新回收的盘块中,再将其盘块号作为新栈底。

相关文档
最新文档