<Linux>(极简关键、省时省力)《Linux操作系统原理分析之文件管理(1)》(22)

《Linux操作系统原理分析之文件管理(1)》(22)

  • 7 文件管理
    • 7.1 文件与文件系统
      • 7.1.1 文件
      • 7.1.3 文件系统及其功能
    • 7.2 文件的组织结构
      • 7.2.1 文件的逻辑结构
      • 7.2.2 文件的物理结构
        • 一、顺序结构(顺序文件或连续文件)
        • 二、链接结构(链接文件或串联文件)
        • 三、索引结构(索引文件)

7 文件管理

7.1 文件与文件系统

7.1.1 文件

文件:具有文件名的一组信息组合,包括两部分:
文件体:文件本身的信息;
文件说明:文件存储和管理信息;如:文件名、文件内部标识、文件存储地址、访问权限、访问时间等;

7.1.2 文件的种类
文件系统在管理文件时还要识别和区分文件的类型,如果是文件系统所确认的文件类型,则可根据类型对文件进行合理的操作。
(1)按用途分类
系统文件、库文件和用户文件。
(2)按保护级别分类
根据限定的使用文件的权限:执行文件、只读文件和读写文件等。
(3)按信息流向分类
物理设备的特性决定了文件信息的流向:输入文件、输出文件和输入输出文件。
(4)按文件的性质分类
根据文件的性质分:普通文件、目录文件、设备文件等。
(5)按文件的组织结构分类
由用户组织的文件称逻辑文件:流式文件和记录式文件。
文件在存储介质上的组织方式称文件的物理结构(物理文件):顺序文件、链接文件和索引文件等。

7.1.3 文件系统及其功能

  1. 文件系统:操作系统中管理文件的机构,提供文件存储、提供文件在外存中的组织方式,以及文件访
    问控制等功能。文件系统的三个部分:管理软件、被管理软件、相关的数据结构
  2. 文件系统的功能 :
    (1)目录管理

文件目录是实现按名存取的一种手段。 建立一个新文件,应把与该文件有关的一些属性登记在文件目录中;
读一个文件,应从文件目录中查找指定文件是否存在并核对是否有权使用。
一个好的目录结构应既能方便检索,又能保证文件的安全。

(2)文件的组织

用户按信息的使用和处理方式组织文件,称为文件的逻辑结构或称为逻辑文件。把逻辑文件保存到存储介质上的工作由文件系统来做,这样可减轻用户的负担。根据用户对文件的存取方式和存储介质的特性,文件在存储介质上可以有多种组织形式。把文件在存储介质上的组织方式称为文件的物理结构或称为物理文件。因此,当用户要求保存文件时,文件系统必须把逻辑文件转换成物理文件,而当用户要求读文件时,文件系统又要把物理文件转换成逻辑文件。

(3)文件存储空间的管理

要把文件保存到存储介质上时,必须记住哪些存储空间已被占用,哪些存储空间是空闲的。文件只能保存到空闲的存储空间中,否则会破坏已保存的信息。当文件没有必要再保留而被删除时,该文件所占的存储空间应成为空闲空间。

(4)文件操作

为了保证文件系统正确地存储和检索文件,规定了在一个文件上可执行的操作,这些可执行的操作统称为“文件操作”。文件系统提供的基本文件操作有建立文件、打开文件、读文件、写文件、关闭文件和删除文件等。“文件操作”是文件系统提供给用户使用文件的一组接口,用户调用“文件操作”提出对文件的操作要求。

(5)文件的共享、保护和保密

在多道程序设计的系统中,有些文件是可以共享的,例如,编译程序、库文件等。实现文件共享既节省文件的存放空间,又可减少传送文件的时间,但必须对文件采取安全保护措施。既要防止有意或无意地破坏文件,又要避免随意地剽窃文件。

7.2 文件的组织结构

7.2.1 文件的逻辑结构

逻辑结构:它是用户所观察到的文件组织形式,是用户可以直接处理的数据及结构,它独立于物理特性,又称为文件组织(file organization)。
分类:
a. 有结构记录式文件(数据库):包含若干顺序排列的记录
👉 变长记录:数据项/字段不同;数据项本身不同。
👉 定长记录:文件长度=记录总个数×记录长。
b. 无结构字符流式文件:文件的信息不组成记录,文件的长度即为字符总个数。(源程序、文本文件)

7.2.2 文件的物理结构

  1. 物理结构:文件在外存上的实际的组织形式。
    1) 物理块:以物理块为基本单位分配和传输信息,物理块大小由存储设备和 OS 确定。
    2) 物理块大小与逻辑记录大小之间不一定一致。
  2. 文件物理结构的几种形式:1)顺序结构件 2)链接结构 3)索引结构
一、顺序结构(顺序文件或连续文件)

一个文件在逻辑上连续的信息被存放到磁盘上依次相邻的块上。逻辑记录顺序与磁盘块的顺序相一致。
例:在这里插入图片描述

优点:存取速度快、结构简单、支持顺序存取和随机存取。
存在的问题:
(1)磁盘存储空间的利用率不高,容易产生碎片。
(2)对输出文件很难估计需多少磁盘块。
(3)影响文件的扩展。

二、链接结构(链接文件或串联文件)

基本思想:将文件存放在外存中若干个物理块中,这些物理块不必连续。每个物理块的最后一个单元用作指针,指向下一个物理块的地址。最后一块中的指针可用特殊字符(例如“-1”)表示文件到此结束, 从而将同一个文件的物理块链接起来。
优点:解决了顺序结构中的所有问题。
在这里插入图片描述

磁盘上所有空闲块都可以被利用;
建立文件时也不必事先考虑文件的长度,文件可继续扩展;
便于在文件的任何位置插入一个记录或删除一个记录。
缺点:采用随机存取方式是低效的。文件只能按指针链接顺序访问,故存取速度慢;
可靠性问题,如指针出错。
链接指针占用一定的空间。
读出一块信息时,应将其中的指针分离出来,保证用户使用信息的正确性。

三、索引结构(索引文件)

基本思想:为每一个文件建立一张索引表,每一表项记录文件所在的一个物理块。
在这里插入图片描述
优点:能方便地实现文件的扩展、记录的插入和删除。
缺点:必须增加索引表占用的空间和读写索引表的时间。索引表的查找策略对文件系统效率影响很大.
索引表的管理:当索引表非常大时,需要多个磁盘块存放,各磁盘块之间可用指针链起来。当随机存取某个记录时,可能要沿链搜索才能找到该记录的存放地址,很费时间。
解决方案:多级索引、混合索引(下例适用 Unix System V)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/218238.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

微信小程序uni.chooseImage()无效解决方案

Bug场景: 微信小程序在上传图片时可以通过 uni.chooseImage()方案进行上传,这里不再赘述具体参数。一直项目都可以正常使用,突然有一天发现无法使用该方法,于是查了一下,发现是用户隐私协议问题。故记录一下解决方案。…

Linux中的网络配置

本章主要介绍网络配置的方法 网络基础知识查看网络信息图形化界面修改通过配置文件修改 1.1 网络基础知识 一台主机需要配置必要的网络信息,才可以连接到互联网。需要的配置网络信息包括IP、 子网掩码、网关和 DNS 1.1.1 IP地址 在计算机中对IP的标记使用的是3…

逻辑回归 使用Numpy实现逻辑回归

使用Numpy实现逻辑回归 sigmoid 函数 g ( z ) 1 ( 1 e − z ) g(z)\frac{1}{(1e^{−z} )} g(z)(1e−z)1​ # sigmoid 函数 def sigmod(z):return 1/(1np.exp(-z))线性计算与梯度下降 J ( θ ) − 1 m [ ∑ i 1 m y ( i ) l o g ⁡ ( h θ ( x ( i ) ) ) ( 1 − y ( i ) …

【计算机网络笔记】物理层——物理介质

系列文章目录 什么是计算机网络? 什么是网络协议? 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能(1)——速率、带宽、延迟 计算机网络性能(2)…

Linux socket编程(10):UDP详解、聊天室实现及进阶知识

首先来回顾以下TCP的知识,TCP是一种面向连接的、可靠的传输协议,具有以下特点: TCP通过三次握手建立连接,确保通信的可靠性和完整性使用流控制和拥塞控制机制,有效地调整数据传输的速率,防止网络拥塞TCP提…

redis的keys命令和scan命令性能对比

项目场景 Redis的keys *命令在生产环境是慎用的,特别是一些并发量很大的项目,原因是Redis是单线程的,keys *会引发Redis锁,占用reids CPU,如果key数量很大而且并发是比较大的情况,效率是很慢的&#xff0c…

vivado实现分析与收敛技巧9-分析使用率统计数据

实现问题的常见原因之一是未考量显式和隐式物理约束。例如 , 管脚分配 (pinout) 在逻辑布局上变为显式物理约束。 slice( 分片 ) 逻辑在大部分器件中都是一致的。但如下专用资源表示的是隐式物理约束 , 因为这些资源仅在某些位置…

C语言碎片知识

sizeof 1.sizeof是C语言中的一个操作符,同时也是关键字!!!! 2.sizeof的操作数可以是类型,变量或表达式 如图,第一个为什么是6?,因为先计算了3的大小,占4个字…

【模电】放大电路的组成原则

放大电路的组成原则 组成原则常用的两种共射放大电路 组成原则 通过对基本共射放大电路的简单分析可以总结出,在组成放大电路时必须遵循以下几个原则:    1. 必须根据所用放大管的类型提供直流电源,以便设置合适的静态工作点,并…

【unity3D】unity中如何查找和获取游戏物体

💗 未来的游戏开发程序媛,现在的努力学习菜鸡 💦本专栏是我关于游戏开发的学习笔记 🈶本篇是unity中游戏物体的查找与获取 这里写自定义目录标题 获取当前物体的基本属性查找其它物体- 通过名称查找其它物体- 通过标签查找- 通过类…

互联网Java工程师面试题·Spring Boot篇·第二弹

目录 8、什么是 YAML? 9、如何实现 Spring Boot 应用程序的安全性? 10、如何集成 Spring Boot 和 ActiveMQ? 11、如何使用 Spring Boot 实现分页和排序? 12、什么是 Swagger?你用 Spring Boot 实现了它吗? …

MySQL之时间戳(DateTime和TimeStamp)

MySQL之时间戳(DateTime和TimeStamp) 文章目录: MySQL之时间戳(DateTime和TimeStamp)一、DateTime类型二、TimeStamp类型三、DateTime和TimeStamp的区别 当插入数据时,需要自动记录一个时间时候&#xff0c…

【springboot】整合redis

1.前提条件:docker安装好了redis确定redis可以访问 可选软件: 2.测试代码 (1)redis依赖 org.springframework.boot spring-boot-starter-data-redis (2)配置redis (3) 注入 Resource StringRedisTemplate stringRedisTemplate; 对键进行操作 –o…

SCTransform normalization seurat

完成了前面的基础质控、过滤以及去除细胞周期的影响后,我们可以开始SCTransform normalization。 SCTransform normalization的优势: 1️⃣ 一个SCTransform函数即可替代NormalizeData, ScaleData, FindVariableFeatures三个函数;2️⃣ 对测序深度的校正…

[足式机器人]Part2 Dr. CAN学习笔记-Ch0-1矩阵的导数运算

本文仅供学习使用 本文参考: B站:DR_CAN Dr. CAN学习笔记-Ch0-1矩阵的导数运算 1. 标量向量方程对向量求导,分母布局,分子布局1.1 标量方程对向量的导数1.2 向量方程对向量的导数 2. 案例分析,线性回归3. 矩阵求导的链…

DCDC电源的选择

https://blog.csdn.net/xiahailong90/article/details/79086490 先说结论: 高开关频率的交换式电源转换器有利也有弊,本文提到的好处包括体积更小、瞬时响应更快以及电压overshoot 和undershoot 值都更小,主要缺点则是效率降低和热量增加。 …

STK Components 二次开发-飞行器

1.创建飞机 参数帮助文档 var poitList GetTracksData(); var waypointPropagator new WaypointPropagator(m_earth, poitList); var locationPoint waypointPropagator.CreatePoint();m_aircraft new Platform {Name "MH730",LocationPoint locationPoint,Or…

独立版求职招聘平台小程序开发

小程序招聘系统开发 我们开发了一款高效、便捷的互联网招聘平台。在这里,可以轻松实现企业入驻、职位发布、在线求职、精准匹配职位和人才,以及参与招聘会等功能。目标是为求职者和企业搭建一个连接彼此的桥梁,帮助您更快地找到满意的工作&…

基于Go语言实现简易Web应用

目录 前言Go语言特点写在使用Go语言实现Web应用前面创建Web服务器声明一个结构体操作加入中间件的使用使用静态文件服务器最后 前言 在编程语言中,近几年问世的几个新语言都是非常不错的,比如Go、Python、 Rust等等。其中,Go语言(Golang)作…

线程池、及Springboot线程池实践

摘要 本文介绍了线程池基本概念、线程及线程池状态、java中线程池提交task后执行流程、Executors线程池工具类、最后介绍在springboot框架下使用线程池和定时线程池,以及task取消 线程池基本 背景 线程池 线程池是一种多线程处理形式,处理过程中将任务…
最新文章