【linux基础I/O(二)】文件系统讲解以及文件缓冲区的概念

简介: 【linux基础I/O(二)】文件系统讲解以及文件缓冲区的概念

1. 前言

对于文件来讲,有打开的在内存中

的文件,也有没有打开的在磁盘上

文件,上一篇文章讲解的是前者,本篇

文章将带大家了解后者!

本章重点:

本篇文章着重讲解在磁盘中的文件的
存储方式以及inode相关概念.在这之前
会解释C语言缓冲区的概念以及作用,
最后会带大家了解软硬链接如何创建,
软硬链接的区别,理解动静态库


2. 理解C语言的缓冲区

缓冲区的本质就是一段内存空间

那么为什么要有缓冲区?讲个例子

你在云南大学想要将一本书送给你在
北京邮电大学的好友,你会亲自将书带
过去给他然后再回云南吗?显然不可能
你会去楼下的顺丰快递将书籍让顺丰帮
你寄到北京区,你就代表一个用户,而书籍
就是你要发送给其他用户的数据,顺丰就
是这个缓冲区.很明显缓冲区有以下性质:

  • 顺丰拿到你的快递立刻发送(立刻刷新)
  • 等累计快递达到一定数量统一发送(行刷新)
  • 或者当快递站放满了再发送快递(满刷新)

行缓存的设备文件: 显示器(关心用户体验)
全缓存的设备文件: 磁盘文件(关心效率)

执行下面的代码时,不会立刻打印出信息:

printf("abcdef");
sleep(5);
return 0;

因为printf后没有\n刷新缓冲区,所以

信息不会立刻打印出来,当休眠五秒

后程序退出时才会进行刷新缓冲区!

函数fflush可以强制刷新缓冲区

除此之外,既然操作系统只认识文件描述符
fd,所以C语言的FILE结构体中一定封装了fd
,并且C语言的缓冲区实际上也是在FILE结构
体中维护的!也就是说直接使用系统调用去进
行输出工作是不会有缓冲区的概念的!


3. 对文件系统的初认识

对于已经在内存中打开的文件来说,它的

结构无非就是OS为它创建的struct file,

但是对于未打开的文件也就是存储在磁盘

上的文件,是怎样管理的呢?

看看关于磁盘结构的剖析图:

磁盘看似是一张盘面,实际上内部分为

很多个面,一个面对于一个磁头,这是正

视图的磁盘,再来看看俯视图的磁盘:

对于磁盘的每一个面来说,并不是所有
的区域都可以用来存储数据,可以把特
定的磁道中特定的扇区看作是一个小
数组,此小数组中存储文件的属性内容
一般而言一个扇区的大小是512字节

所以我们把把整个磁盘文件的管理
细拆分为对一个扇区的管理!!!


4. 扇区中的块组是如何工作的?

每个扇区是512字节的大小,每个分区会

划分不同的块组,将所有的块组管理好也

就将整个磁盘管理好来了!

块组的基本结构:

  • inode Table保存对应文件的属性.每一个inode块都有一个inode编号,也就是说一个文件,一个inode,一个inode编号
  • Block Bitmap是个位图,表示特定的块组是否被使用
  • inode Bitmap也是个位图,表示特定的inode是否被占用
  • Data Blocks存储此文件的内容
  • GDT是块组描述符,表征这个块组有多大,已被使用了多少,有多少个inode,还剩多少个等等.
  • SuperBlock保存着文件系统的属性信息,每个块组都会备份一份,里面有每一个块组的信息

从今往后,要在磁盘中找到一个文件只需: 找到inode编号->分区特定的块组->inode->属性->内容
那么问题是文件的inode是什么我怎么知道?是的,
OS都考虑好了,在文件的目录中,存放着文件名和此文件的inode对应的映射关系,可以通过文件名直接找到inode!!!


5. 理解软硬链接

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

使用指令: ln 创建硬链接

使用方法: ln 已存在的文件 要创建的硬链接

可以发现,在创建硬链接前,test.cpp的引用计数是1,而创建硬链接后计数变成了2,其实硬链接的本质就是给相同的文件取别名,硬链接没有自己的inode,它和原文件的inode相同!请看下面的图片验证:

使用指令: ln -s 创建软连接

使用方法: ln -s 已存在的文件 要创建的硬链接

可以发现,创建的软连接是独立的一个文件,它有自己的inode,并且此软连接指向原文件,软链接相当于Windows下的创建快捷方式一样,它可以将文件路径很复杂的文件创建一个软链接到当前目录,想要使用原文件时,只需要使用软链接即可!


6. 理解动静态库

  • 静态库(.a结尾): 程序在编译链接时就把库的代码链接到可执行程序
  • 动态库(.so结尾): 程序运行时才去链接动态库的代码,动态库的代码是被共享的

gcc/g++默认使用的动态链接的方式,若

想要变为静态链接,在编译时加上-static

如何写一个自己的库?

.h文件写声明,.c写实现,将.c文件

编译成.o文件后,再将所有的.o文件

通过指针ar打包成一个库,将这个库

和.h文件放在同一目录,别人就能用了

制作静态库指令:

ar -rc libhello.a mymath.o myprintf.o

制作动态库指令:

gcc -shared myadd.o myprintf.o -o libhello.so

当别人要使用你写的库时,需要在编译
时带上选项-l加上你的库名,就像后面
在学习线程库时要加上选项-lpthread
,它的意思就是要使用pthread线程库


7. 总结

Linux的基础IO部分已经全部讲解

完毕,下一章将进入进程信号的学习.

掌握文件的inode相关知识可以更好

的帮助我们理解文件在打开和关闭时

分别是怎样运作的!


🔎 下期预告:Linux信号 🔍


相关文章
|
7月前
|
Linux
【Linux】 Linux文件I/O常见操作技巧
以上就是Linux文件I/O操作的一些技巧,接纳它们,让它们成为你在Linux世界中的得力伙伴,工作会变得轻松许多。不过记住,技巧的运用也需要根据实际情况灵活掌握,毕竟,最适合的才是最好的。
247 28
|
7月前
|
NoSQL Linux 编译器
GDB符号表概念和在Linux下获取符号表的方法
通过掌握这些关于GDB符号表的知识,你可以更好地管理和理解你的程序,希望这些知识可以帮助你更有效地进行调试工作。
356 16
|
7月前
|
Unix Linux
对于Linux的进程概念以及进程状态的理解和解析
现在,我们已经了解了Linux进程的基础知识和进程状态的理解了。这就像我们理解了城市中行人的行走和行为模式!希望这个形象的例子能帮助我们更好地理解这个重要的概念,并在实际应用中发挥作用。
150 20
|
6月前
|
存储 Linux Shell
Linux进程概念-详细版(二)
在Linux进程概念-详细版(一)中我们解释了什么是进程,以及进程的各种状态,已经对进程有了一定的认识,那么这篇文章将会继续补全上篇文章剩余没有说到的,进程优先级,环境变量,程序地址空间,进程地址空间,以及调度队列。
138 0
|
6月前
|
Linux 调度 C语言
Linux进程概念-详细版(一)
子进程与父进程代码共享,其子进程直接用父进程的代码,其自己本身无代码,所以子进程无法改动代码,平时所说的修改是修改的数据。为什么要创建子进程:为了让其父子进程执行不同的代码块。子进程的数据相对于父进程是会进行写时拷贝(COW)。
191 0
|
9月前
|
自然语言处理 监控 Linux
Linux 内核源码分析---proc 文件系统
`proc`文件系统是Linux内核中一个灵活而强大的工具,提供了一个与内核数据结构交互的接口。通过本文的分析,我们深入探讨了 `proc`文件系统的实现原理,包括其初始化、文件的创建与操作、动态内容生成等方面。通过对这些内容的理解,开发者可以更好地利用 `proc`文件系统来监控和调试内核,同时也为系统管理提供了便利的工具。
519 16
|
9月前
|
存储 Linux 调度
【Linux】进程概念和进程状态
本文详细介绍了Linux系统中进程的核心概念与管理机制。从进程的定义出发,阐述了其作为操作系统资源管理的基本单位的重要性,并深入解析了task_struct结构体的内容及其在进程管理中的作用。同时,文章讲解了进程的基本操作(如获取PID、查看进程信息等)、父进程与子进程的关系(重点分析fork函数)、以及进程的三种主要状态(运行、阻塞、挂起)。此外,还探讨了Linux特有的进程状态表示和孤儿进程的处理方式。通过学习这些内容,读者可以更好地理解Linux进程的运行原理并优化系统性能。
374 4
|
存储 监控 安全
《Linux 简易速速上手小册》第6章: 磁盘管理与文件系统(2024 最新版)
《Linux 简易速速上手小册》第6章: 磁盘管理与文件系统(2024 最新版)
150 1
|
存储 监控 Linux
|
Linux
第七章、Linux磁盘与文件系统管理
第七章、Linux磁盘与文件系统管理
214 0