标准IO与系统IO

news/2024/10/6 4:21:23/文章来源:https://www.cnblogs.com/hhail08/p/18287503

C平台的标准IO(可跨系统)

image


Linux 系统IO (Linux系统平台才能使用)

image


Linux系统的IO(输入输出)特点主要包括以下几个方面

1)文件视为一切:在Linux中,几乎所有的设备和资源都被视为文件。这意味着无论是硬件设备(如磁盘、网络接口)还是系统资源(如进程、内存),它们都可以通过文件系统进行访问和操作。2)异步IO支持:Linux提供了异步IO(AIO)的支持,允许应用程序发起IO操作后可以继续执行其他任务,而不必等待IO操作完成。这对于高性能的应用程序特别有用,可以充分利用系统资源。3)多路复用:Linux提供了多路复用机制,如select()、poll()、epoll()等,允许应用程序监视多个文件描述符的IO状态,当其中任何一个文件描述符就绪(可读、可写等)时,通知应用程序进行处理。这种机制可以有效地减少不必要的轮询开销,提高IO效率。4)缓存层:Linux通过页缓存(page cache)来优化文件IO的性能。它会将文件的内容缓存在内存中,当应用程序需要读取或写入文件时,可以直接在内存中操作,减少了与物理设备的直接交互次数,提高了IO的速度。5)支持多种文件系统:Linux支持多种文件系统,如ext4、XFS、Btrfs等,每种文件系统都有不同的特点和适用场景。这种灵活性使得Linux能够在不同的应用场景中选择合适的文件系统以达到最佳的IO性能和可靠性。总体来说,Linux系统在IO方面的设计强调了性能、可扩展性和灵活性,通过文件视为一切、异步IO、多路复用和缓存等机制,为应用程序提供了高效的IO操作支持。

Linux文件IO的缓存层具有以下几个特点

页缓存(Page Cache):页缓存是Linux内核中的一部分,用于缓存从磁盘读取的数据。它使用了一种称为内存映射的技术,将文件数据映射到内存页面中。当应用程序进行文件读写操作时,首先会尝试从页缓存中获取数据,而不是直接访问磁盘,从而显著提高了IO操作的性能。写回缓存(Write-back Cache):当应用程序执行写操作时,数据首先被写入页缓存,然后在适当的时候(例如当缓存满了或经过一定时间后)再写回磁盘。这种机制称为写回(write-back)。写回策略可以减少磁盘写入次数,提高系统性能,但也意味着在断电或系统崩溃时有可能丢失未写入磁盘的数据。读前缓存(Read-ahead Cache):为了提升顺序读取性能,Linux缓存层会进行读前(read-ahead)操作。在检测到顺序读模式时,内核会预先将接下来的数据块加载到页缓存中,使得后续的读取操作更快,因为数据已经在内存中。脏页管理(Dirty Page Management):被修改但尚未写回磁盘的页面称为脏页(dirty pages)。Linux内核会跟踪这些脏页,并在合适的时机将其写回磁盘。通过脏页管理机制,内核可以优化写操作,减少对磁盘的频繁访问。缓存一致性:Linux内核确保页缓存与磁盘数据的一致性。如果有多个进程同时访问相同的文件,内核会通过锁机制和缓存协调来保证数据一致性,避免数据冲突和不一致。缓存淘汰策略:页缓存占用的内存不能无限增长,因此Linux内核使用缓存淘汰策略(如Least Recently Used, LRU)来管理缓存的大小。当内存资源紧张时,内核会根据使用情况选择较少使用的页面从缓存中移除,以释放内存空间。Direct IO(直接IO):虽然缓存层提供了很多优势,但在某些情况下,应用程序可能希望绕过缓存直接进行磁盘IO。Linux支持Direct IO(通过O_DIRECT标志),允许应用程序将数据直接读写到磁盘上,避免缓存层的干扰。这对于数据库等需要严格管理IO行为的应用非常有用。内存映射文件(Memory-mapped Files):内存映射文件是一种将文件内容映射到进程地址空间的机制。利用这种方式,进程可以像访问内存一样访问文件数据,依赖于页缓存来提高效率。

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

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

相关文章

比snipaste更好用的截图工具 pixpin

pixpin官网功能介绍与 snipaste 的功能相似,比snipaste好用作者:mohistH 出处:https://www.cnblogs.com/pandamohist/ 本文版权归作者和博客园共有,谢绝一切形式的转载,否则将追究法律责任。

HT-014 Div3 扫雷 题解 [ 绿 ] [ 二维差分 ]

分析 观察到是曼哈顿距离 \(\le r\) 的范围可以扫到,联想到如下图形:左边是 \(r=1\) 可以扫到的范围,右边是 \(r=2\) 可以扫到的范围。 于是,我们只要对这样的图形在 \(1000*1000\) 的格子里差分一下就好了 。 但这样的复杂度是 \(O(nm)\) 的,会死的很惨。 优化 不难发现这…

[VSCode] Add all missing import

https://github.com/microsoft/vscode-docs/blob/vnext/release-notes/v1_46.md#add-all-missing-imports-source-action

秒杀圣经:10Wqps高并发秒杀,16大架构杀招,帮你秒变架构师

文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录 博客园版 为您奉上珍贵的学习资源 : 免费赠送 :《尼恩Java面试宝典》 持续更新+ 史上最全 + 面试必备 2000页+ 面试必备 + 大厂必备 +涨薪必备 免费赠送 :《尼恩技术圣经+高并发系列PDF》 ,帮你 实现技术自由,…

《从零开始学习Python爬虫:顶点小说全网爬取实战》

文章优势:最新内容更新:最近几天整理,包含最新的爬虫技术和实践经验。 精致内容汇总:基于培训课程笔记,内容丰富、详细,适合初学者入门及进阶。顶点小说 装xpath helper GitHub - mic1on/xpath-helper-plus: 这是一个xpath开发者的工具,可以帮助开发者快速的定位网页元素…

LRU算法简介

LRU(Least Recently Used,最近最少使用)算法是一种常用于缓存管理的算法,用于在缓存空间有限的情况下,决定哪些数据应该被移除。它的基本思想是:如果一个数据最近被访问过,那么在将来一段时间内它被再次访问的概率较高。因此,当缓存已满,需要移除数据时,优先移除那些…

数据结构小学期第六天

今天完全实现了九宫格拼图游戏,具备一键通关功能按下W键,查看原图功能按住A键不松,移动图片按上下左右键,如果你自己想要实现这个功能,需要自己的图片,图片格式要求。 每个小图片是105*105,完整图片是315*315.有人想要做一下,可以试一试。代码如下 启动类1 import com.…

1、flask-基本架构-MVT - 虚拟环境的安装 - 创建flask应用

flask基本架构图 创建虚拟环境 #1. 打开cmd或pycharm都可以(确保安装python环境) #2. 安装虚拟环境模块-windows - pip install virtualenv virtualenvwrapper-win#3. 查看虚拟环境 - workon#4. 创建虚拟环境 - mkvirtualenv flask2env - 默认创建在:C:\Users\Administrato…

基于Qwen2/Lllama3等大模型,部署团队私有化RAG知识库系统的详细教程(Docker+AnythingLLM)

大语言模型在垂直细分领域存在知识局限、幻觉、数据安全等一些问题,可通过RAG(检索增强生成)方案来解决。本文基于AnythingLLM框架,搭建团队私有知识库系统,并进行使用和验证,RAG系统在保留输出的有效性同时,还保留了创造性……自 ChatGPT 发布以来,大型语言模型(Larg…

基于STM32F1系列,驱动L298N电机驱动板实现直流电机的启动、停止、调速功能

一. L298N电机驱动板电源引脚 VCC 外接直流电源引脚,电压范围在5~35V之间 GND GND是接地引脚,连接到电源负极 5V 驱动芯片内部逻辑供电引脚,如果安装了5V跳帽,则此引脚可输出5V电压,为微控板或其他电路提供电力供给,如果拔掉5V跳帽,则需要独立外接5V电源 控制引脚 IN1 &…

SpringBoot引入WebSocket

WebSocket 是一种在客户端和服务器之间提供低延迟、全双工通信的网络协议。它允许双方在建立一次连接后,进行实时、持续的数据交换,无需像HTTP那样为每一个请求和响应建立新的连接。WebSocket的设计初衷是解决传统HTTP协议在实时通信方面的不足,比如实现实时聊天、游戏、股票…

博客园商业之路:全园求偶遇,懂园子懂商业的创业合伙人

各方面的因素将园子的商业化强推到一个关口,2024年7月-9月是决定园子命运的一个季度,我们将拼尽所有力气找各种可能的突破口,不会有任何保留。 这个关口是最后关头,也是三年多来最好的时间窗口,天时地利最需要人和,找到对的人,最有可能在这个时间窗口,一将解园子二十年…