快速过一遍计算机基础--操作系统—4.文件管理

本文详细介绍了文件管理的相关知识,包括文件的逻辑结构、文件目录、文件控制块FCB及其优化、文件的物理结构(连续分配、链接分配、索引分配)、逻辑结构与物理结构的区别,以及文件的基本操作、存储空间管理和磁盘管理等内容,是理解操作系统文件系统的重要参考资料。
摘要由CSDN通过智能技术生成

目录

Part 1:文件的逻辑结构

Part 2:文件目录

一、实现文件目录的关键数据结构----文件控制块FCB

二、目录结构

三、对文件控制块FCB的优化—索引结点

Part 3:文件的物理结构(文件分配方式)

一、文件的三种分配方式

1.连续分配

2.链接分配

3.索引分配

二、辨别逻辑结构和物理结构

1.链式存储 vs 链式分配

2.索引文件 vs 索引分配

3.需想清楚的点

Part 4:文件的基本操作

Part 5:文件存储空间管理

一、存储空间的划分和初始化

二、存储空间的管理方法

Part 6:文件共享、文件保护、文件系统的层次结构

Part 7:关于磁盘

一、磁盘的结构

二、磁盘调度算法

三、减少一次磁盘读写操作的时间----减少延迟时间

四、磁盘的管理


Part 1:文件的逻辑结构

1.无结构文件(流式文件):本质是一系列二进制或字符流,没有明显的结构特性,不做讨论。

2.有结构文件(记录式文件,可分为定长记录和可变长记录)

(1)顺序文件(文件中的记录逻辑上顺序排列)

  1. 记录可定长可变长
  2. 又分为串结构(顺序与关键字无关)和顺序结构(顺序按关键字顺序排列)
  3. 可顺序存储可链式存储

(2)索引文件

  1. 建立一张索引表加快文件检索速度,每条记录对应一个索引项(链接文件中的记录),文件中的记录在物理上可以离散地存放。
  2. 索引表本身是定长记录的顺序文件,可随机存取。

(3)索引顺序文件

  1. 为了解决索引表过大的问题,索引表的索引项对应的是一组记录;每个分组就是一个顺序文件,分组内记录不需要按关键字排序。
  2. 多级索引顺序文件

Part 2:文件目录

一、实现文件目录的关键数据结构----文件控制块FCB

  1. FCB:目录文件中的一个记录,包含的字段有“文件名”“类型”“存储权限”“物理位置”等。
  2. 需要对目录进行的操作:搜索,创建/删除/文件,显示/修改目录

二、目录结构

1.单级目录结构:不允许文件重名,不适用于多用户系统。

2.两级目录结构:分为主文件目录和用户文件目录,允许不同用户的文件重名。

3.多级目录结构(树形):不同目录下的文件可以重名,但不利于实现文件的共享。

4.无环图目录结构:可以用不同的文件名指向同一个文件,需要为每一个共享结点设置一个共享计数器。

三、对文件控制块FCB的优化—索引结点

  1. 新建索引表,索引结点中的信息仅包含文件名以及指向文件目录文件的指针。
  2. 磁盘索引结点,内存索引结点(增加一些信息如“文件是否被修改”、“此时有几个进程正在访问该结点”)

操作系统实验(含实验报告) 1、进程调度 2、作业调度 3、主存空间的分配与回收 4、文件系统 一、 实验目的 用高级语言编写和调试一个进程调度程序,以加深对进程的概念及进程调度算法的理解。 二、实验内容和要求 编写并调试一个模拟的进程调度程序,采用“简单时间片轮转法”调度算法对五个进程进行调度。 每个进程有一个进程控制块( PCB)表示。进程控制块可以包含如下信息:进程名、到达时间、需要运行时间、已运行时间、进程状态等等。 进程的到达时间及需要的运行时间可以事先人为地指定(也可以由随机数产生)。进程的到达时间为进程输入的时间。 进程的运行时间以时间片为单位进行计算。 每个进程的状态可以是就绪 W(Wait)、运行R(Run)两种状态之一。 就绪进程获得 CPU后都只能运行一个时间片。用运行时间加1来表示。 如果运行一个时间片后,进程的已占用 CPU时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用CPU时间还未达所需要的运行时间,也就是进程还需要继续运行,此时应分配时间片给就绪队列中排在该进程之后的进程,并将它插入就绪队列队尾。 每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。 重复以上过程,直到所要进程都完成为止。 三、实验主要仪器设备和材料 硬件环境:IBM-PC或兼容机 软件环境:C语言编程环境 四、实验原理及设计方案 1、进程调度算法:采用多级反馈队列调度算法。其基本思想是:当一个新进程进入内在后,首先将它放入第一个队列的末尾,按FCFS原则排队等待高度。当轮到该进程执行时,如能在该时间片内完成,便可准备撤离系统;如果它在一个时间片结束时尚为完成,调度程序便将该进程转入第二队列的末尾,再同样地按FCFS原则等待调度执行,以此类推。 2、实验步骤: (1)按先来先服务算法将进程排成就绪队列。 (2)检查所有队列是否为空,若空则退出,否则将队首进程调入执行。 (3)检查该运行进程是否运行完毕,若运行完毕,则撤消进程,否则,将该进程插入到下一个逻辑队列的队尾。 (4)是否再插入新的进程,若是则把它放到第一逻辑队列的列尾。 (5)重复步骤(2)、(3)、(4),直到就绪队列为空。 。。。。。。。。。。。。。。。。。。。。。。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值