Linux基础I/O(三)——缓冲区和文件系统

文章目录

  • 什么是C语言的缓冲区
  • 理解文件系统
  • 理解软硬链接

什么是C语言的缓冲区

C语言的缓冲区其实就是一部分内存

那么它的作用是什么?
下面有一个例子:

你在陕西,你远在山东的同学要过生日了,你打算送给他一份生日礼物。你有两种方式将礼物送给他。1. 你自己坐火车、坐飞机花费时间送到他的宿舍楼下,再花费同样的时间返回。这样的方式显然是可行的,但是并不可取,因为效率太低了;2. 你将礼物交给楼下的顺丰快递,让顺丰代替你送达,这样就节省了你的时间,同时也提高了效率。顺丰并不会一收到你的快递就发货,而是会积攒到一定的程度,同一发货。

通过上面的故事,我们发现顺丰快递其实就扮演着缓冲区这样的角色,提高效率、很明显缓冲区有以下几种刷新方式:
1、顺丰拿到快递后里面送出<--->缓冲区立即刷新
2、快递积攒一定到程度后发出<--->缓冲区行刷新
3、顺丰快递积满了后同一发出<--->缓冲区全刷新

我们总喜欢输出这样的语句printf("qweasdzxc\n);
这里的\n就是行刷新,如果没有\n的话,我们下面这段代码的情况会是这样的

printf("qweasdzxc");
sleep(3) ;
return 0;

信息不会立刻打印出来,休眠三秒后程序自动退出时会进行一次缓冲区的刷新,因为printf后没有\n进行行刷新
此外还有函数fflush可以进行强制刷新缓冲区

理解文件系统

首先,我们需要知道截止目前为止我们所学的关于文件的知识都是基于文件被打开的。
但是你的系统里有很多文件,那么它们都被打开了吗?
显而易见是不可能的,打开的仅仅只是一小部分;
那么一个文件被打开之前,文件在哪里呢?
这些文件都在磁盘上进行保存。
没有被打开的文件不仅要在磁盘上进行保存,还需要带有规律的进行保存,方便用户进行随时读取,其实就是方便用户随时打开,随时换出内存。
就像是我们去楼下菜鸟驿站取快递,总得有个取件码吧!
这个取件码就很是我们谈到的文件路径;
我们也可以通过文件存放在磁盘上的路径对文件进行快速定位;

菜鸟驿站工作人员所做的工作叫做文件系统,文件系统是我们操作系统的一个分支,操作系统有内存管理,进程管理,也有文件管理等等。

文件系统要作的事情:
1.打开的文件进行管理
2.没有被打开的文件也要在磁盘中进行管理

理解磁盘—硬件——物理存储结构
在这里插入图片描述

在这里插入图片描述
磁盘的寻找方案(CHS定位法)
1.先选择哪一面? — 本质选择磁头
2.选择该面上的哪一个磁道
3.选择在该该磁道的哪一个扇区
所以我们把把整个磁盘文件的管理细拆分为对一个扇区的管理

理解逻辑抽象——逻辑存储结构
在这里插入图片描述

将磁带那些条状的东西拉出来就是上述第一张图那个样子,这个是软性介质,所以我们也可以把它拉的很长,卷起来就是同心圆的样子,拉直了就是一根长长的直线,磁盘的盘面卷起来就是圆状的。我们也可以把磁盘盘片抽象成一个线性结构。
在这里插入图片描述

为了提高一定的效率,所以进行了规定,以8个扇区为基本单位,也就是一个文件块来进行访问 (8*512 = 4096字节,也就是4KB)。我们只需要知道起始的地址,我们就可以访问8个扇区,我们把这种地址叫做LBA地址、逻辑块地址 Logical Block Address
在这里插入图片描述

对存储设备的管理在操作系统层面转换成了对(4KB blocks[])数组的增删查改。


笔记本电脑有500GB大的磁盘空间,这个空间想要直接管理起来是非常困难的。那么我们可以类比国家下面有省、有市、有区、有镇、有村。这样就将一个大区域分为了多个小区域,那么对于这500GB来说也是一样的。我们利用分治的思想将这500GB转换为对多个100GB,然后我们还可以把这100GB划分成50个2GB的组。
在这里插入图片描述
我们把这些组叫做块组,这些块组里面存的数据有两种,1.我的文件信息;2.很多的文件管理的数据
其中,写入的管理信息是什么是由文件系统决定的,不同的文件系统格式化时写入的管理信息是不同的,常见的文件系统有EXT2、EXT3、XFS、NTFS等。

在Linux操作系统中,我们也可以通过以下命令查看我们磁盘的分区信息:
在Linux操作系统中,我们也可以通过以下命令查看我们磁盘的分区信息:
在这里插入图片描述

使用文件系统之前,要把每一个组当中的管理数据写入到块组当中。就是块组里面的各个分区都要先写入管理数据(分区使用了多大的空间,还剩多少空间),我们把这个操作称之为格式化。

在这里插入图片描述


文件系统会根据分区的大小将其划分为一个个的块组
在这里插入图片描述

  • inode Table::存放文件属性 如 文件大小,所有者,最近修改时间等;
struct inode//128字节
{//大小、权限、拥有者、所属组、ACM时间、inode编号...
}
  • Data Blocks: 存放文件内容。
  • Block Bitmap: 块位图当中记录着Data Block中哪个数据块已经被占用,哪个数据块没有被占用。
  • inode Bitmap: inode位图当中记录着每个inode是否空闲可用。
  • Group Descriptor Table: 块组描述符表,描述该分区当中块组的属性信息。
  • 超级块(Super Block):存放文件系统本身的结构信息。记录的信息主要有:bolck 和 inode的总量,未使用的block和inode的数量,一个block和inode的大小,最近一次挂载的时间,最近一次写入数据的时间,最近一次检验磁盘的时间等其他文件系统的相关信息。Super Block的信息被破坏,可以说整个文件系统结构就被破坏了。Super Block并不属于某一个块。

磁盘分区并格式化后,每个分区的inode个数就确定了。


要在磁盘中找到一个文件只需: 找到inode编号、分区特定的块组、inode、属性、内容

将属性和数据分开存放的想法看起来很简单,但实际上是如何工作的呢?我们通过touch一个新文件来看看如何工作。
在这里插入图片描述
创建一个新文件主要有一下4个操作:

  1. 存储属性
    内核先找到一个空闲的i节点(这里是263466)。内核把文件信息记录到其中。
  2. 存储数据
    该文件需要存储在三个磁盘块,内核找到了三个空闲块:300,500,800。将内核缓冲区的第一块数据
    复制到300,下一块复制到500,以此类推。
  3. 记录分配情况
    文件内容按顺序300,500,800存放。内核在inode上的磁盘分布区记录了上述块列表。
  4. 添加文件名到目录
    新的文件名abc。linux如何在当前的目录中记录这个文件?内核将入口(263466,abc)添加到目录文
    件。文件名和inode之间的对应关系将文件名和文件的内容及属性连接起来。

创建文件:遍历inode Bitmap位图中找0,申请一个未被使用的inode,填入属性信息。并把这个映射关系写到当前目录的Data blocks中。

查看目录:根据目录inode找到与其映射的文件名。

向文件写入:遍历block Map找到若干未被使用的块儿,将该文件的inode与这些blocks建立映射关系,再向blocks中写入内容。

查看文件内容:cat hello.c → 查看当前目录lesson15的data Blocks数据块儿 → 找到映射关系:文件名儿对应的inode编号 → 在inode Table中找到inode → 找到对应的blocks[] → 打印文件内容。 查看文件属性类似。


因为Linux下一切皆文件,所以目录也是文件。目录也有自己的属性信息,目录的inode结构当中存储的就是目录的属性信息,比如目录的大小、目录的拥有者等。

理解软硬链接

真正找到磁盘上文件的并不是文件名,而是inode。
其实在linux中可以让多个文件名对应于同一个inode,这就是硬链接的原理;

ln 文件名 硬链接
在这里插入图片描述

在创建硬链接前,test.c的引用计数是1,而创建硬链接后计数变成了2,其实硬链接的本质就是给相同的文件取别名,硬链接没有自己的inode,它和原文件的inode相同!如下图:
在这里插入图片描述

ln -s 文件名 软链接
在这里插入图片描述

我们发现创建的软链接是一个新的文件具有自己的inode,并且此软链接指向原文件,软链接其实就是Windows下的快捷方式,它一个路径很长的文件创建一个软链接到当前目录,使用原文件时,只需要使用它的软链接就行了。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ //练习 5.24 修改你的程序,使得当第二个数是0时抛出异常。先不要设定catch子句,运行程序并真的为除数输入0,看看会发生什么?

C Primer&#xff08;第5版&#xff09; 练习 5.24 练习 5.24 修改你的程序&#xff0c;使得当第二个数是0时抛出异常。先不要设定catch子句&#xff0c;运行程序并真的为除数输入0&#xff0c;看看会发生什么&#xff1f; 环境&#xff1a;Linux Ubuntu&#xff08;云服务器…

使用 devc++ 开发 easyx 实现 Direct2D 交互

代码为 codebus 另一先生的 文案 EasyX 的三种绘图抗锯齿方法 - CodeBus 这里移植到 devc 移植操作如下&#xff1a; 调用dev 的链接库方式&#xff1a; project -> project option -> 如图所示 稍作修改的代码。 #include <graphics.h> #include <d2d1.…

springboot175图书管理系统

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

Java实现教学资源共享平台 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课程资源模块2.4 课程作业模块2.5 课程评价模块 三、系统设计3.1 用例设计3.2 类图设计3.3 数据库设计3.3.1 课程档案表3.3.2 课程资源表3.3.3 课程作业表3.3.4 课程评价表 四、系统展…

算法村目录

大家好我是苏麟 , 这是算法村使用目录 . 算法通关村 从链表到动态规划的实战 目录 算法村开篇第一关 了解链表第二关 链表专题第三关 数组专题第四关 栈专题第五关 队列专题第六关 树专题第七关 二叉树遍历专题第八关 二叉树专题第九关 二分查找与二叉树专题第十关 快速排序与归…

springBoot,springSecurity返回乱码

框架&#xff1a;SpringBoot3 问题&#xff1a;响应内容乱码 问题代码&#xff1a; // 成功登录响应的内容Overridepublic void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication…

备战蓝桥杯---组合数学基础1

让我们来几道高中的组合题吧&#xff1a; 1.我们一定有n个向下&#xff0c;为 2.我们挑最大的两个&#xff0c;条件是他们奇偶性相同&#xff0c;为2*A10,2; 3.用捆绑法即可。 4.我们用隔板法&#xff0c;为 5.问题等价于23个相同的球放到3个盒子里&#xff0c;每个盒子至少…

Centos9部署LAMP

配置LAMP 参考文档 https://blog.csdn.net/weixin_51432789/article/details/112254685 首先安装 yum install -y libxml2-devel 安装apr-1.7.4 解压 tar xf apr-1.7.4.tar.gz 安装以来 yum -y install gcc cd apr-1.7.4/ 预编译 ./configure --prefix/usr/local/…

视频讲解:优化柱状图

你好&#xff0c;我是郭震 AI数据可视化 第三集&#xff1a;美化柱状图&#xff0c;完整视频如下所示&#xff1a; 美化后效果前后对比&#xff0c;前&#xff1a; 后&#xff1a; 附完整案例源码&#xff1a; util.py文件 import platformdef get_os():os_name platform.syst…

HiveSQL——设计一张最近180天的注册、活跃留存表

0 问题描述 现有一个用户活跃表user_active(user_id,active_date)、 用户注册表user_regist(user_id,regist_date)&#xff0c;表中分区字段都为dt(yyyy-MM-dd)&#xff0c;用户字段均为user_id; 设计一张 1-180天的注册活跃留存表&#xff1b;表结构如下&#xff1a; 1 数据分…

文件包含知识点详细总结

如果想看图片和观感更好的话,可以直接去我的github或者gitbook github:https://github.com/kakaandhanhan/cybersecurity_knowledge_book-gitbook.22kaka.fun gitbook:http://22kaka.fun description: 这里将通过参考文章和做题一起进行总结,并且文件包含漏洞,很多都利用了…