操作系统——设备管理
0.关注博主有更多知识
操作系统入门知识合集
目录
1.设备管理概念
2.SPOOLing技术
1.设备管理概念
在计算中,除CPU、内存以外的所有设备统称为外设,即外部设备,例如鼠标、键盘、打印机、摄像头、磁盘、硬盘......那么这些只需要连接到计算机便可使用,那么操作系统是如何管理这些设备的呢?
设备的分类:
1.按交互对象分类:
1)人机交互设备:显示设备、键盘、鼠标、打印机
2)与CPU交互的设备:磁盘、磁带、传感器、控制器
3)计算机之间的通信设备:网卡、调制解调器(光猫)
2.按交互方向分类:
1)输入设备:键盘、鼠标、扫描仪
2)输出设备:显示设备、打印机
3)双向设备:硬盘、软盘、网卡
3.按外设特性分类;
1)使用特征:存储、输入、输出
2)数据传输速率:低速(例如键盘)、中速(例如打印机)、高速(例如网卡、磁盘)
3)信息组织特征:字符设备(例如打印机)、块设备(例如磁盘)、网络设备。其中字符设备以字节为单位进行数据传送;块设备以块为单位进行数据传送,操作系统当中有缓冲区
这些设备与计算机的交互原理是千变万化且复杂的,这里不再赘述。
设备管理的主要功能:
1.设备分配
2.设备映射
3.设备驱动
设备分配:
1.设备分配功能是操作系统对设备管理的基本任务
2.设备分配程序按照一定的策略,为申请设备的进程分配设备,并记录设备的使用情况。操作系统需要一定的策略来分配设备,因为设备往往只有一份,如果分配的策略不合理,就会造成进程对设备的资源竞争,导致死锁。
设备映射:
1.物理设备:I/O系统中实际安装的设备,它具有一个很长的序列号用来标识唯一的物理名
2.逻辑设备(虚拟设备):应用软件(进程)使用的设备,该逻辑设备具有一个简短的友好名来表示该设备
3.设备映射功能:
1)设备管理模块将逻辑设备映射到物理设备,即应用软件使用的设备都是逻辑设备(虚拟设备)
2)从应用软件的角度看,逻辑设备是一类物理设备的抽象
3)从设备管理模块的角度看,物理设备是逻辑设备的实例
设备独立性:
1.物理设备对于用户来说是透明的(即用户不可见),用户使用统一规范的方式使用设备
2.用户编程时使用设备的逻辑名,由操作系统实现逻辑设备到物理设备的转换
Linux友好名例子:实际上在Linux当中有"一切皆文件"的概念,即Linux将所有设备当成文件处理,那么调用open打开指定的文件时就是在某种意义上就是在使用设备:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>int main()
{// Linux下一切皆文件int fd = open("./hello.txt",O_RDONLY);if(fd != -1){// 这里只是个举例char buffer[64];int n = read(fd,buffer,sizeof(buffer));if(n > 0){buffer[n] = 0;printf("%s\n",buffer);}}return 0;
}
设备驱动:
1.驱动程序对物理设备进程控制,使用[IN/OUT]指令实现对物理设备的I/O控制
2.驱动程序用户软件的服务请求(例如读写命令),转换为具体的I/O指令,以完成对物理设备的控制
3.用户使用驱动程序提供的统一接口来控制设备,也就是说,用户不需要使用[IN/OUT]指令,驱动程序内部将自动完成命令转化的工作。驱动程序提供的接口例如read、write、open......(以Linux为例)
4.特点:
1)设备驱动程序与硬件密切相关
2)每类设备都要配置特定的驱动程序
3)驱动程序一般由设备厂商根据操作系统的要求编写
4)操作系统仅对设备驱动的接口提出要求(操作系统不关系硬件是如何实现的,只关系驱动程序)
2.SPOOLing技术
在谈SPOOLing系统之前,先介绍一下设备分配的方法:
1.独占设备的分配
2.共享设备的分配
3.虚拟分配
独占设备分配:
1.任意一个设备在任意时刻只能被一个进程占用
2.进程要使用设备时,首先向操作系统申请,如果申请成功,则正常使用该设备;申请失败进入阻塞状态。当设备可用时,操作系统唤醒因为申请设备失败而阻塞的进程;进程使用设备结束之后,必须及时释放该设备
3.独占设备的分配过程:申请——使用——释放
进程申请设备->操作系统分配设备->进程发送使用命令->操作系统将该命令转发到驱动程序,让驱动程序控制设备完成一次I/O传输->进程释放设备->操作系统回收设备。在这个过程当中,进程一旦申请设备成功,在其释放设备资源之前,一直独占该设备
共享设备分配:共享设备包括所有的块设备,即传输数据时以块为单位:
1.宏观上,一个共享型设备可以被多个进程同时占用
2.微观上,多个进程交替使用同一设备
3.进程使用该类设备时,无需申请或释放设备,也不存在某个进程占用设备的问题
4.共享设备的分配过程:
1)进程使用共享型设备时不需要申请设备资源
2)实际上,I/O期间只能有一个进程使用设备。因此,进程使用共享型设备之前有一个隐含的申请命令;使用设备结束时有一个隐含的释放命令。也就是说,在进程与设备进行I/O期间,必须保证排他性,即必须保证互斥
3)使用共享型设备的过程中,进程也可能进入阻塞状态
虚拟分配:
1.虚拟技术:在一类物理设备上模拟另一类物理设备的技术。即借助辅存的部分区域模拟独占设备,将独占设备转化为共享设备
2.虚拟设备:
1)用来模拟独占设备的部分辅存称为虚拟设备,也就是以辅存的部分空间虚拟化独占设备
2)输入井:模拟输入设备的辅存区域
3)输出井:模拟输出设备的辅存区域
3.虚拟分配:
1)当进程需要与独占设备交换信息时,就采用虚拟技术将该独占设备虚拟化成对应的虚拟设备(即部分辅存空间),将该虚拟设备分配给进程
2)操作系统使用SPOOLing技术实现对独占设备的虚拟化和虚拟设备的分配。SPOOLling,Simultaneous Periphernal Operations OnLine,即外部设备同时联机操作,是一种假脱机输入/输出操作。何为脱机?即脱离主机的控制进行I/O操作。而假脱机指的是进行I/O操作系统不脱离主机,但是能达到脱机的效果。
4.SPOOLing例子:
如上图图(2),输入监控进程和输出监控进程模拟脱机系统的卫星机。用户进程将输出数据先送到输出井,当输出设备空闲时,再将输出井的数据经过输出缓冲区送到输出设备上;同理,输入设备将输入的数据先送到输入井,再送给用户进程。
SPOOLing结构:
1.输入井和输出井:由辅存开辟的两个存储区域模拟而成
2.输入缓冲区和输出缓冲区:这些缓冲区在内存当中开辟。输入缓冲区,暂存输入数据,后面再送到输入井;输出缓冲区,暂存输出数据,后面再送到输出设备
3.输入监控进程和输出监控进程:输入监控进程模拟脱机输入的卫星机,将用户要求的数据从输入设备通过输入缓冲区送到输入井。当用户进程需要数据时,直接从输入井读取数据;输出监控进程模拟脱机输出的卫星机,将用户进程要输出的数据先送到输出井,当输出设备空闲时,将数据送到输出缓冲区,再送到输出设备上。
SPOOLing原理:假设用户进程的任务为先设备读数据再向写设备数据
1.预先将程序和数据送到输入井中
2.需要使用数据时,从输入井取出数据
3.需要输出数据时,将数据写入输出井
4.设备空闲时将要输出的数据从输出井输出到输出设备上
综上,SOOLing技术提高了I/O的效率,将独占设备虚拟成了共享设备,实现了虚拟设备的功能。
相关文章:

操作系统——设备管理
0.关注博主有更多知识 操作系统入门知识合集 目录 1.设备管理概念 2.SPOOLing技术 1.设备管理概念 在计算中,除CPU、内存以外的所有设备统称为外设,即外部设备,例如鼠标、键盘、打印机、摄像头、磁盘、硬盘......那么这些只需要连接到计…...

图片分类:精细化分类,(Fine-Grained Categorization) 基于人的行为的精细化分类
文字大纲 简介数据集常用数据集方法1 : 强监督方法2 : 弱监督传统 ResNet EfficientNet 等Two Level Attention Model双线性网络 Bilinear CNN model参考文献和学习路径简介 细粒度图像识别 (fine-grained image recognition),即 精细化分类。 细粒度图像分类(Fine-Graine…...

Matlab2012a的图像处理工具箱的imshow函数
在处理图片文件时,除了使用matlab自带的image函数,还可以考虑用matlab的图像处理工具箱。这个工具箱提供了imshow和imtool两个函数,可实现图片的显示。 这两个函数都支持Handle Graphics体系结构,它们可创建图像对象,…...

Linux_红帽8学习笔记分享_10(SELinux管理与防火墙)
Linux_红帽8学习笔记分享_10(SELinux管理与防火墙) 文章目录 Linux_红帽8学习笔记分享_10(**SELinux管理与防火墙**)1.Linux系统的安全机制1.1 Filesystem1.2 Service1.3 Firewall1.4 SELinux 2.SElinux理论概述3.SElinux的配置文件3.1 SELINUX参数3.2 SELINUXTYPE参数 4.查看和…...
【资料分享】
文章目录 前言《408统考,真题&解析(2009-2021)》《Android 移动应用基础教程(Android Studio)(第2版)》黑马程序员 源代码《Hackers & Painters》--Paul Graham《数字电路与逻辑设计(第3版…...

NewBing 还无法访问的几个问题
大部分的AI自媒体都在说,Bing new已经向全世界开放了,我也凑一下这个热闹,用Edge浏览器打开,访问https://www.bing.com/new?ccus 想体验一下Bing new的效果,结果如下: 相信很多人都碰到了这个问题 此体验…...

将 Segment Anything 扩展到医学图像领域
文章目录 前言技术交流SAM 拆解分析从医学角度理解 SAM 的效用MedSAM实验总结 前言 SAM 是一种在自然图像分割方面取得成功的模型,但在医学图像分割方面表现不佳。MedSAM 首次尝试将 SAM 的成功扩展到医学图像,并成为用于分割各种医学图像的通用工具。为…...

毕业5年,技术越来越好,混的却越来越差...
别人都是越来越好,而我是越来越差! 17年,从一个普通的本科毕业,那个时候的我,很迷茫,简历上的求职岗位都不知道写什么,因为家里是农村的,朴实的父母也帮不上什么忙,关于…...
C#实现把txt文本数据快速读取到excel中
主要介绍了C#实现把txt文本数据快速读取到excel中,本文直接给出示例代码,需要的朋友可以参考下 今天预实现一功能,将txt中的数据转到excel表中,做为matlab的数据源。搜集一些c#操作excel的程序。步骤如下: 下载一个Microsoft.Office.Interop.Excel.dll 在项目中引用。 编…...
Office转换需要用到的SDK(建议)
PDF相关SDK1. PDFBox:一个基于Java的开源库,可以读取、创建和操作PDF文件。2. iText:一个用于Java和.NET的开源库,可以创建、编辑和操作PDF文件。3. MuPDF:一个轻量级的开源PDF阅读器和渲染器,可用于创建和…...
python语法入门到面向过程编程(二)
类型总结 一:整形基本使用(int) 1 int用途:年龄 号码 等级… 2 定义方式 age10 ageint(10) xint(‘1111’) int只能将纯数字的字符串转成十进制的整型 print(type(x)) 3 整形常用操作内置的方法 算数运算(、—、*、/࿰…...

Java常用类
基本数据类型包装类 Java是一种纯面向对象语言,但是java中有8种基本数据类型,破坏了java为纯面向对象的特征。为了承诺在java中一切皆对象,java又给每种基本数据类型分别匹配了一个类,这个类我们称之为包装类/封装类。每个基本数据…...

4.30下周美联储携非农来袭黄金多空该如何布局?
近期有哪些消息面影响黄金走势?下周黄金多空该如何研判? 黄金消息面解析:周五(4月28日)当周金价维持震荡交投,金价基本持稳于2000美元下方。支撑和打压金价的因素参半。经济衰退的担忧,以及避险情绪支持金价&#x…...
利用python查找指定目录下大于300M的文件
直接上代码,欢迎小伙伴们交流 import os def getBigFile(path, filesize): # 遍历指定目录及其子目录 for dirpath, dirnames, filenames in os.walk(path): for filename in filenames: target_file os.path.join(dirpath, filename…...

浅尝ChatGPT使用之Python字典嵌套排序
一、背景 所负责的项目从v1.0升级到v2.0之后,发送到kafka的Json数据字段顺序和内容有所改变, v1.0版本推送数据样例: {"name": "小王子","author": "安托万德圣-埃克苏佩里(1900-1944&#…...

最大网络流算法之dinic算法详解
1、题目描述 On the Internet, machines (nodes) are richly interconnected, and many paths may exist between a given pair of nodes. The total message-carrying capacity (bandwidth) between two given nodes is the maximal amount of data per unit time that can b…...
051、面试必刷TOP101--链表(230503)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言链表1、BM1 反转链表2、BM2 链表内指定区间反转3、BM3 链表中的节点每k个一组翻转4、BM4 合并两个排序的链表5、BM5 合并k个已排序的链表6、BM6 判断链表中是否…...

开源中国面试准备
dockerFile常见命令 1、FROM 设置要制作的镜像基于哪个镜像,FROM指令必须是整个Dockerfile的第一个指令,如果指定的镜像不存在默认会自动从Docker Hub上下载 2、MAINTAINER 镜像作者的信息,比如名字或邮箱地址 语法:MAINTAINER n…...
基于J2EE的B2C电子商务系统开发与实现
摘要 当今社会,科学技术突飞猛进,知识经济初见端倪。电子商务作为一种新型的贸易方式,极大地促进了全球经济贸易的发展,同时也正在改变人们的生活方式和思想观念。电子商务是指整个贸易活动实现电子化,交易各方以电子交易方式而进行的商业交易。世界贸易组织电子商务专题报告定…...

三分钟教你看懂 spring 官方文档
新手如何学会查看官方文档API 首先进入官网:这里以 spring boot 为例 ,进入spring 官方地址 我们进入 spring boot 这里我们要看文档当然是要 learn 了,所以点进去。 我需要的东西在 IO 模块里面,点 IO 进入 发送邮件是不是有了…...

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
Cursor实现用excel数据填充word模版的方法
cursor主页:https://www.cursor.com/ 任务目标:把excel格式的数据里的单元格,按照某一个固定模版填充到word中 文章目录 注意事项逐步生成程序1. 确定格式2. 调试程序 注意事项 直接给一个excel文件和最终呈现的word文件的示例,…...

大话软工笔记—需求分析概述
需求分析,就是要对需求调研收集到的资料信息逐个地进行拆分、研究,从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要,后续设计的依据主要来自于需求分析的成果,包括: 项目的目的…...

MODBUS TCP转CANopen 技术赋能高效协同作业
在现代工业自动化领域,MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步,这两种通讯协议也正在被逐步融合,形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...
Python爬虫(二):爬虫完整流程
爬虫完整流程详解(7大核心步骤实战技巧) 一、爬虫完整工作流程 以下是爬虫开发的完整流程,我将结合具体技术点和实战经验展开说明: 1. 目标分析与前期准备 网站技术分析: 使用浏览器开发者工具(F12&…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...

3-11单元格区域边界定位(End属性)学习笔记
返回一个Range 对象,只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意:它移动的位置必须是相连的有内容的单元格…...

STM32HAL库USART源代码解析及应用
STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...
django blank 与 null的区别
1.blank blank控制表单验证时是否允许字段为空 2.null null控制数据库层面是否为空 但是,要注意以下几点: Django的表单验证与null无关:null参数控制的是数据库层面字段是否可以为NULL,而blank参数控制的是Django表单验证时字…...

华为OD机试-最短木板长度-二分法(A卷,100分)
此题是一个最大化最小值的典型例题, 因为搜索范围是有界的,上界最大木板长度补充的全部木料长度,下界最小木板长度; 即left0,right10^6; 我们可以设置一个候选值x(mid),将木板的长度全部都补充到x,如果成功…...