第四章 文件管理 六、文件的基本操作

目录

一、创建文件(create系统调用)

1、进行Create系统调用时,需要提供的几个主要参数:

2、操作系统在处理Create系统调用时,主要做了两件事:

二、删除文件(delete系统调用)

1、进行Delete系统调用时,需要提供的几个主要参数:

2、操作系统在处理Delete系统调用时,主要做了几件事:

三、读文件(read系统调用)

四、写文件(write系统调用)

五、打开文件(open系统调用)

1、在很多操作系统中,在对文件进行操作之前,要求用户先使用open系统调用"打开文件",需要提供的几个主要参数:

2、操作系统在处理open系乡统问门的,工要做了几件事:

六、关闭文件(close系统调用)

七、总结


一、创建文件(create系统调用)

1、进行Create系统调用时,需要提供的几个主要参数:

  • 1.所需的外存空间大小(如:一个盘块,即1KB)
  • 2.文件存放路径(("D:/Demo")
  • 3..文件名(这个地方默认为"新建文本文档.txt")

2、操作系统在处理Create系统调用时,主要做了两件事:

  • 1.在外存中找到文件所需的空间(结合,空闲链表法、位示图、成组链接法等管理策略,找到空闲空间)
  • 2.根据文件存放路径的信息找到该目录对应的目录文件(此处就是D:/Demo目录),在目录中创建该文件对应的目录项。目录项中包含了文件名、文件在外存中的存放位置等信息。

二、删除文件(delete系统调用)

1、进行Delete系统调用时,需要提供的几个主要参数:

  • 1.文件存放路径("D:/Demo")
  • 2.文件名("test.txt")

2、操作系统在处理Delete系统调用时,主要做了几件事:

  • 1.根据文件存放路径找到相应的目录文件,从目录中找到文件名对应的目录项。
  • 2.根据该目录项记录的文件在外存的存放位置、文件大小等信息,回收文件占用的磁盘块。(回收磁盘块时,根据空闲表法、空闲链表法、位图法等管理策略的不同,需要做不同的处理)
  • 3.从目录表中删除文件对应的目录项。

三、读文件(read系统调用)

四、写文件(write系统调用)

五、打开文件(open系统调用)

1、在很多操作系统中,在对文件进行操作之前,要求用户先使用open系统调用"打开文件",需要提供的几个主要参数:

  • 1.文件存放路径("D:/Demo")
  • 2.文件名( "test.txt")
  • 3.要对文件的操作类型(如: r只读;rw读写等)

2、操作系统在处理open系乡统问门的,工要做了几件事:

  • 1.根据文件存放路径找到相应的目录文件,从目录中找到文件名对应的的目录项,并检查该用户是否有指定的操作权限。
  • 2.将目录项复制到内存中的"打开文件表"中。并将对应表目的编号返回给用户。之后用户使用打开文件表的编号来指明要操作的文件。

六、关闭文件(close系统调用)

七、总结

相关推荐
zone_z8 分钟前
Oracle 表空间检查与监控配置详解
数据库·oracle
冉冰学姐1 小时前
SSM装修服务网站5ff59(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·ssm 框架·装修服务网站
库库8391 小时前
Redis分布式锁、Redisson及Redis红锁知识点总结
数据库·redis·分布式
沧澜sincerely1 小时前
Redis 缓存模式与注解缓存
数据库·redis·缓存
Elastic 中国社区官方博客2 小时前
Elasticsearch 推理 API 增加了开放的可定制服务
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
nzxzn3 小时前
MYSQL第二次作业
数据库·mysql
核桃杏仁粉3 小时前
excel拼接数据库
数据库·oracle·excel
TiAmo zhang3 小时前
SQL Server 2019实验 │ 设计数据库的完整性
数据库·sqlserver
冻咸鱼4 小时前
MySQL的CRUD
数据库·mysql·oracle
Funny Valentine-js4 小时前
团队作业——概要设计和数据库设计
数据库