OS复习笔记ch11-3

news2024/10/25 2:20:26

接下来,我们简单地回顾一下I/O缓冲(之前在ch5-4-1的时候有提到过)

I/O缓冲

image.png
背景:
假设进程I/O需要在灰色区间读写,而灰色区间由于阻塞而被对换出去了,此时OS找不到对应的内存地址,这样就容易发生死锁。所以为了避免上述问题,就要“提前输入,延迟输出”。

  • 提前输入(Pre-fetching or Read-ahead)

提前输入是一种数据处理技术,它预先从输入源(如硬盘、网络等)读取数据到一个临时存储区域(即缓冲区)。这样做的目的是减少等待时间和提高数据访问速度。通过预先加载数据,系统可以迅速地获取必要的数据,而不必在每次需要时才去源头读取,这通常涉及更高的延迟。

  • 延迟输出(Write-behind or Delayed Writing)

延迟输出是指将输出操作暂存到缓冲区中,而不是立即写入目标(如硬盘)。这允许系统合并多个输出操作为较少的、更大块的写入操作,从而减少对输出设备的访问次数。这种策略可以有效减少写操作引起的性能瓶颈,特别是在目标设备相对较慢的情况下。

一般来说,缓冲区是OS在内存中专门开辟的一个空间,并且缓冲区常驻内存。如果缓冲区为空,没有相关文件,就必须要到外设去读写。

缓冲的目的

  • 匹配 CPU或用户应用进程与外设的不同处理速度
  • 协调逻辑记录大小与物理记录大小不一致
  • 提高CPU和I/O设备之间的并行性
  • 各个I/O设备之间的处理并行性

注:物理记录相当于物理设备上的数据记录,而加载到缓冲区之后,就可以根据进程需要的内容传递相应的逻辑记录

缓冲区的等待

  • 在输出数据时,只有在系统还来不及腾空缓冲而进程又要写数据时,它才需要等待;
  • 在输入数据时,仅当缓冲区空而进程又要从中读取数据时,它才被迫等待。

缓冲的分类:

  • 块缓冲(block-oriented buffering)
  • 字符缓冲(stream-oriented buffering)

这里的缓冲分类,对应我们的外围设备中的块设备和字符设备,接下来我们会具体讲不同缓冲区的特点。

单缓冲(Single Buffer)

  1. 基于块的单缓冲

image.png

需要提前读,但是每次只能读一块数据,这样到下次进程需要,直接从缓冲区取就行

image.png
C是calculate的简写,M是move,T是transfer
这里我们了解一下C,T,M的具体含义

  • T代表数据从设备上传输到系统缓冲区的时间
  • M代表进程从系统缓冲区读取数据到工作/用户区的时间(视为访存)
  • C代表的是进程实际对数据的运算加工的时间

对C和M进行比较,可以看出该进程的类型(如果 C >> M,是CPU型,反之是I/O型进程)
2. 基于字符流的单缓冲
image.png

字符终端,键盘/显示器一般是行缓冲(输入或者输出的过程中遇到换行符时,才执行真正的输入输出操作),某些特殊设备也可以基于字节缓冲

双缓冲(Double Buffer)

image.png

由于 M<< T,M 就忽略不计,实际上不一定满足

  • 当C<=T时,max[C,T] = T,也就是说设备的传输时间大于CPU计算时间,此时CPU快速消耗缓冲区数据,外设就可以源源不断的给缓冲区提供数据,即保证了设备的连续工作
  • 反之,CPU计算时间较长,那么多缓冲可以保证进程输入或者输出数据在CPU计算完成前,也就是进程不需要一直等待I/O提供数据,即保证进程不等I/O

PS:当 M 不远小于 T 的时候,需要考虑 M 的时间,此时要放在 C 这边,即处理一个数据块的平均耗时是 Max(T, C+M)

循环缓冲(Circular Buffer)

image.png

  • 不止一个缓冲区
  • 每一个缓冲区是一个独立的单元
  • 常见于I/O需要与进程保持同步的时候

缓冲池(Buffer Pool)

e.g., Linux中的循环缓冲
image.png
这张图片是关于早期 Linux 系统(特别是 LINUX 0.1X 版本)的内存管理和启动过程的视觉说明。图中详细展示了系统内存从 0 到 16M(兆字节)的分配和利用情况
image.png
空闲列表具体实现使用的是结构体数组,通过指针串成了双向的循环列表,每一个结构体有一个指向缓冲块的指针。
image.png
使用hash表结构,用一个散列数组将每一个已经分配的缓冲列表串起来
e.g., 字符缓冲
image.png
这里可以对照了解一下hello.c的执行全过程,不再详细叙述。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Shell脚本、相关命令;重定向、管道符、变量相关命令讲解

目录 Shell脚本 概念 执行命令流程的交互区别 交互式 非交互式 Shell脚本应用场景 Shell的作用 Shell的作用 —— 命令解释器&#xff0c;“翻译官” 列出系统中全部解释器 实验 脚本的基本书写格式和执行命令 在子bash下执行脚本 指定解释器的方式执行脚本 指定…

nodejs的await和async

例子 const fs require(fs).promises;async function getFileContent(filePath) {const content await fs.readFile(filePath, utf8); console.log(content); // 这行会在文件读取完成后执行 }getFileContent(example.txt); console.log(123); // 这行会立即执行输出结果&…

/usr/bin/ld: 当搜索用于 /lib/i386-linux-gnu/libcuda.so 时跳过不兼容的 -lcuda

/usr/bin/ld: 当搜索用于 /lib/i386-linux-gnu/libcuda.so 时跳过不兼容的 -lcuda ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/023dbdeb215b4b4580f7f54706e32af9.pn当使用unsloth做微调时&#xff0c;发现找不到libcuda&#xff0c;很自然想到需要软链接到最新…

2024最新AI大模型-LLm八股合集(八)-Transformer模型

更多2024最新AI大模型-LLm八股合集可以拉到文末&#xff01;&#xff01;&#xff01; MHA & MQA & MGA &#xff08;1&#xff09;MHA 从多头注意力的结构图中&#xff0c;貌似这个所谓的多个头就是指多组线性变换层&#xff0c;其实并不是&#xff0c;只有使用了一…

PS去除logo背景

一、打开图片 二、点击通道选择色差最明显的通道 三、复制通道 四、点击载入 五、反选ctrlshifti&#xff08;鼠标右键亦可&#xff0c;然后调整下范围&#xff09; 六、点击图层&#xff0c;复制图层&#xff08;ctrlJ&#xff09; &#xff08;先确保图层是解锁的&#xff0…

二叉树-输出二叉树的右视图

目录 一、问题描述 二、解题思路 三、代码实现 四、刷题链接 一、问题描述 二、解题思路 这里右视图类似于立方体的右视图&#xff0c;从右边看每一层第一个看到的结点的集合就是需要返回的结果&#xff0c;注意返回的结点是有相对顺序的&#xff0c;比如上面的1,3,5对应第…

[WTL/Win32]_[中级]_[MVP架构在实际项目中的应用]

场景 在开发Windows和macOS的界面软件时&#xff0c;Windows用的是WTL/Win32技术&#xff0c;而macOS用的是Cocoa技术。而两种技术的本地语言一个主打是C,另一个却是Object-c。界面软件的源码随着项目功能增多而增多&#xff0c;这就会给同步Windows和macOS的功能造成很大负担…

APM Profile 在系统可观测体系中的应用

引言 应用程序性能分析&#xff08;Application Performance Management&#xff0c;APM&#xff09;是一个广泛的概念&#xff0c;涉及应用程序运行时各种性能指标的监测、诊断和优化。在可观测体系建设中&#xff0c;APM 是保障系统业务运行性能的关键技术&#xff0c;确保用…

堆优化版Dijkstra求最短路-java

主要通过堆优化Dijkstra算法解决最短路&#xff0c;可以跟朴素版的Dijkstra算法进行对比。 文章目录 前言 一、Dijkstra求最短路 二、算法思路 1.邻接表存储图 2.用小根堆优化Dijkstra 三、代码如下 1.代码如下&#xff08;示例&#xff09;&#xff1a; 2.读入数据 3.代码运行…

OpenGL绘制Bezier曲面

Bezier的定义 贝塞尔曲面是贝塞尔曲线在二维上的扩展。它由一组控制点定义,通过这些控制点生成光滑的曲面。贝塞尔曲面通常用两个参数 u u u和 v v v来表示,这两个参数的取值范围都在 [0, 1] 之间。 数学表示 P ( u , v ) = ∑ i = 0 n ∑ j = 0 m p i j ⋅ B i , n ( u ) ⋅…

基于ysoserial的深度利用研究(命令回显与内存马)

0x01 前言 很多小伙伴做反序列化漏洞的研究都是以命令执行为目标&#xff0c;本地测试最喜欢的就是弹计算器&#xff0c;但没有对反序列化漏洞进行深入研究&#xff0c;例如如何回显命令执行的结果&#xff0c;如何加载内存马。 遇到了一个实际环境中的反序列化漏洞&#xff…

text2vec 如何选择 chunksize 和 splitter?

0x00 导读 对 text2vec 来说&#xff0c;chunksize 选多大合适&#xff1f; 应该选择哪种 splitter &#xff1f; BCE 还是 BGE &#xff1f; 面对这些 RAG 问题&#xff0c;本文根据 text2vec 模型原理做假设&#xff0c;并用 HuixiangDou 真实数据验证&#xff0c;最终给出…

上海晋名室外危化品暂存柜助力国有控股高科技企业危化品安全储存

近日又有一台SAVEST室外危化品暂存柜项目成功验收交付使用&#xff0c;此次项目主要用于国有控股高科技企业油漆、固化剂及一些危废品的安全储存。 用户单位是一家国有控股、产权多元化的现代高科技企业。用户在日常工作运营中涉及到油漆、固化剂等危化品及一些危废品的室外安…

鄂州职业大学2024年成人高等继续教育招生简章

鄂州职业大学&#xff0c;作为一所享有盛誉的高等学府&#xff0c;一直以来都致力于为社会培养具备专业技能和良好素养的优秀人才。在成人高等继续教育领域&#xff0c;该校同样表现出色&#xff0c;为广大渴望继续深造、提升自身能力的成年人提供了宝贵的学习机会。 随着社会…

android关于源码编译简单的apk处理

文章目录 简述文件的添加 简述 创建AOSP源码可编译一个简单apk的过程&#xff0c;代码子目录结构图如下所示 文件的添加 1.com.custom.test目录下创建TestActivity.java文件 用于简单的界面显示类 package com.custom.test;import android.app.Activity; import android.o…

DY-110DP低电压继电器 25-124V 嵌入式安装 约瑟JOSEF

系列型号 DY-110电压继电器&#xff1b;GY-110电压继电器&#xff1b; GDY-110电压继电器&#xff1b;DY-110/AC电压继电器&#xff1b; GY-110/AC电压继电器&#xff1b;GDY-110/AC电压继电器&#xff1b; DL-110电压继电器&#xff1b;GL-110电压继电器&#xff1b; DL-…

【SD3的Turbo也来了】Jasper AI用Flash Diffusion的蒸馏技术为SD3提速

Flash Diffusion 是一种新颖的图像生成方法&#xff0c;旨在显著提高现有条件扩散模型&#xff08;例如教师模型&#xff09;的速度&#xff0c;而无需牺牲性能。它通过引入以下技术来实现这一点&#xff1a; 蒸馏损失&#xff1a;在教师模型和学生模型之间引入蒸馏损失&#…

深信服科技:2023网络钓鱼趋势分析报告

随着互联网的快速发展和广泛应用&#xff0c;网络钓鱼活动带来的安全隐患愈演愈烈。因应威胁发展&#xff0c;我 们编撰了此份分析报告&#xff0c;旨在全面了解其发展态势&#xff0c;并提醒相关部门、企业和公众加强防范。 在本报告中&#xff0c;我们将详细梳理网络钓鱼的近…

【Git】基础操作

初识Git 版本控制的方式&#xff1a; 集中式版本控制工具&#xff1a;版本库是集中存放在中央服务器的&#xff0c;team里每个人work时从中央服务器下载代码&#xff0c;是必须联网才能工作&#xff0c;局域网或者互联网。个人修改之后要提交到中央版本库 例如&#xff1a;SVM和…

无忧易售新功能:集成图片库智能图片翻译,跨越语言障碍

在电商全球化的浪潮中&#xff0c;跨越语言的障碍&#xff0c;让产品图像说话&#xff0c;成为了商家致胜的关键。"无忧易售ERP"推出集成图片库与图片翻译功能的全新升级&#xff0c;为全球电商提供一站式解决方案&#xff0c;让商品跨越国界&#xff0c;沟通无界。 …