第1章计算机系统漫游之 “操作系统管理硬件“

news2024/12/21 14:51:41

7、操作系统管理硬件

回到 hello 程序的例子。当 shell 加载和运行 hello 程序时,当 hello 程序输出自己的消息时,程序没有直接访问键盘、显示器、磁盘或主存储器。取而代之的是,它们依靠操作系统提供的服务。

可以把操作系统看成是应用程序和硬件之间插入的一层软件,如下图所示:
在这里插入图片描述
所有应用程序对硬件的操作尝试都必须通过操作系统。

操作系统有两个基本功能:防止硬件被失控的应用程序滥用;在控制复杂而又通常广泛不同低级硬件设备方面,为应用程序提供简单一致的方法。

操作系统通过下图中显示的几个基本的抽象概念(进程虚拟存储器和文件)实现这两个功能。文件是对I/O设备的抽象表示,虚拟存储器是对主存和 I/O 设备的抽象表示,进程则是对处理器、主存和 I/O 设备的抽象表示。
在这里插入图片描述

7.1 进程

像 hello 这样的程序在现代系统上运行时,操作系统会提供一种假象,好像系统上只有这个程序在运行。程序看上去是独占地使用处理器、主存和 I/O 设备,而处理器看上去就像不间断地一条接一条地执行程序中的指令。该程序的代码和数据就好像是系统存储器中唯一的对象。这些假象是通过进程的概念来实现的,进程是计算机科学中最重要和最成功的概念之一。

进程 是操作系统对运行程序的一种抽象。在一个系统上可同时运行多个进程,而每个进程都好像在独占地使用硬件。我们称之为并发执行,实际上是说一个进程的指令和另一个进程的指令是交错执行的。操作系统实现这种交错执行的机制称为上下文切换(context switching)。

操作系统保存进程运行所需的所有状态信息。这种状态,也就是上下文(context),包括许多信息,比如PC 和 寄存器文件的当前值,以及主存的内容。在任何一个时刻,系统上都只有一个进程正在运行。当操作系统决定从当前进程转移控制权到某个新进程时,它就会进行上下文切换,即保存当前进程的上下文、恢复新进程的上下文,然后将控制权转移到新进程。新进程就会从它上次停止的地方开始。下图展示了 hello 运行的基本场景。

在这里插入图片描述
示例场景中有两个同时运行的进程:shell 进程和 hello 进程。最开始,只有shell进程在运行,等待命令行上的输入。当我们让它运行 hello 程序时,shell 通过调用一个专门的函数,即 系统调用,来执行我们的请求,系统调用会将控制权传递给操作系统。操作系统保存shell进程的上下文,创建一个新的 hello 进程及其上下文,然后将控制权传给新的 hello 进程。在 hello 进程终止后,操作系统恢复shell进程的上下文,并将控制权传回给它,它会继续等待下一命令行输入。

7.2 线程

尽管通常我们认为一个进程只有单一的控制流,但是在现代操作系统中,一个进程实际上可以由多个称为线程的执行单元组成,每个线程都运行在进程的上下文中,并共享同样的代码和全局数据。由于网络服务器中对并行处理的要求,线程成为越来越重要的编程模型,因为多线程之间比多进程之间更容易共享数据。

7.3 虚拟存储器

虚拟存储器是一个抽象概念,它为每个进程提供了一个假象,好像每个进程都在独占地使用主存。每个进程看到的存储器都是一致的,称之为虚拟地址空间

下图所示的是 Linux 进程的虚拟地址空间(其他Unix系统的设计也与此类似)。

在这里插入图片描述
在 Linux 中,最上面的四分之一的地址空间是预留给操作系统中的代码和数据的,这对所有进程都一样。底部的四分之三的地址空间用来存放用户进程定义的代码和数据。请注意,图中的地址是从下往上增大的。

每个进程看到的虚拟地址空间由大量准确定义的区(area)构成,每个区都有专门的功能。先简单看看每个区,从最低的地址爱是,逐步向上研究是非常有益的。

  • 程序代码和数据

代码是从同一固定地址开始,紧接着的是和 C 全局变量相对应的数据区。代码和数据区是由可执行目标文件直接初始化的,在示例中就是可执行文件 hello。

代码和数据区后紧随着的是运行时。代码和数据区是在进程一旦开始运行时就被指定了大小的,与此不同,作为调用像 malloc 和 free 这样的 C 标准库函数的结果,堆可以在运行时动态地扩展和收缩。

  • 共享库

在地址空间的中间附近是一块用来存放像 C 标准库和数学库这样 共享库 的代码和数据的区域。

位于用户虚拟地址空间顶部的是栈,编译器用它实现函数调用。和堆一样,用户栈在程序执行期间可以动态地扩展和收缩。特别地,每次我们调用一个函数时,栈就会增长。每次我们从函数返回时,栈就会收缩。

  • 内核虚拟存储器

内核是操作系统总是驻留在存储器中的部分。地址空间顶部的四分之一部分是为内核预留的。应用程序不允许读写这个区域的内容或直接调用内核代码定义的函数。


虚拟存储器的运作需要硬件和操作系统软件间的精密复杂的互相合作,包括对处理器生成的每个地址的硬件翻译。基本思想是把一个进程虚拟存储器的内容存储在磁盘上,然后用主存作为磁盘的高速缓存。

7.4 文件

文件只不过就是字节序列。每个 I/O 设备,包括磁盘、键盘、显示器,甚至网络,都可以被看成是文件。系统中的所有输入输出都是通过使用称为 Unix I/O 的一小组系统函数调用读写文件来实现的。

文件使得应用程序能够统一地看待系统中可能含有的所有各式各样的 I/O 设备。例如,处理磁盘文件内容的应用程序员可以非常幸福地无需了解具体的磁盘技术。进一步说,同一个程序可以在使用不同磁盘技术的不同系统上运行。

8、利用网络系统和其他系统通信

现代系统经常是通过网络和其他系统连接到一起的。从一个单独的系统来看,网络可被视为又一个 I/O 设备,如下图所示:

在这里插入图片描述
当系统从主存拷贝一串字符到网络适配器时,数据流经过网络到达另一台机器,而不是到达本地磁盘驱动器。相似地,系统可以读取从其他机器发送来的数据,并把数据拷贝到自己的主存。

随着像 Internet 这样的全球网络的出现,从一台主机拷贝信息到另外一台主机已经成为计算机系统最重要的用途之一。比如,像电子邮件、即时消息发送、万维网、FTP 和 telnet 这样的应用都是基于通过网络拷贝信息的功能的。

回到 hello 示例,可以使用 telnet 应用在一个远程主机上运行 hello 程序。

假设用本地主机上的 telnet 客户端连接远程主机上的 telnet 服务器。在登录到远程主机并运行shell后,远端的 shell 就在等待接收输入的命令。从这点上看,在远端运行 hello 程序包括如下入所示的五个基本步骤:

在这里插入图片描述
当我们在 telnet 客户端键入 “hello” 串并敲下回车键后,客户端软件就会将这个字符串发送到 telnet 的服务器。在 telnet 服务器从网络上接收到这个串后,会把它传递给远端 shell 程序。接下来,远端 shell 运行 hello 程序,并将输出行返回给 telnet 服务器。最后,telnet 服务器通过网络把输出串转发给 telnet 客户端,客户端就将输出串输出到我们的本地终端上。

9、小结

计算机系统是由硬件和系统软件组成的,它们共同协作以运行应用程序。计算机内部的信息被表示为一组组的位,它们依据不同的上下文又有不同的解释方式。程序被其他程序翻译成不同的形式,开始时是 ASCII 文本,然后被编译器和链接器翻译成二级制可执行文件。

处理器读取并解释放在主存里的二进制指令。因为计算机花费了大量的时间在存储器、I/O 设备和 CPU 寄存器之间拷贝数据,所以系统中的存储设备就被按层次排列,CPU 寄存器在顶部,接着是多层的硬件高速缓存存储器、DRAM 主存储器和磁盘存储器。在层次模型中位于更高层的存储设备比低层的存储设备要快,单位比特造价也更高。

操作系统内核是应用程序和硬件之间的媒介。它提供三个基本的抽象概念:文件是对 I/O 设备的抽象概念;虚拟存储器是对主存和磁盘的抽象概念;进程是处理器、主存和I/O设备的抽象概念。

最后,网络提供了计算机系统之间通信的手段。从某个系统的角度来看,网络就是一种 I/O 设备。

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

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

相关文章

王琤:当数据治理遇上ChatGPT

以ChatGPT为代表的人工智能等技术正在“狂飙”,为全球带来一场翻天覆地的变革。4月27日在2023数据治理新实践峰会上,Datablau数语科技创始人&CEO王琤先生以《数据治理新实践与人工智能》为主题进行了分享,与参会同仁共同探索当数据治理遇…

APP开发的上线流程

APP的使用已经非常普及,对于企业来说通过APP可以加强和客户的沟通,展现最新的产品和服务。随着APP应用商店对用户隐私的重视,APP的上线规则比以前更加复杂,甚至出现APP需要反复修改数十次才能上架的问题,今天和大家分享…

移远通信参加2023中国移动5G发展大会 ,共探5G创新未来

5月6日,以“聚力5G创新,共铸百业绽放”为主题的中国移动5G发展大会在郑州国际会展中心召开。作为5G赋能千行百业的重要贡献者,移远通信应邀参加大会,并深度参与了大会的多个环节。 会上,中国移动系列创新成果发布&…

【Linux】Linux安装tomcat(图文解说详细版)

文章目录 1、安装前置条件2、下载所需压缩包,上传到服务器3、对资源进行解压4、给防火墙添加访问端口(默认8080,在它的/conf/server.xml文件里面查看)5、然后切换到bin目录下,启动(成功效果如图&#xff09…

批量任务导致页面卡死解决方案

需求背景 需要基于高德地图展示海量点位(大概几万个),点位样式要自定义(创建DOM),虽然使用了聚合点,但初始化时仍需要将几万个点位的DOM结构都创建出来。 这里补充一句,高德地图在2.…

为什么剑桥出身的“AI教父”辛顿会担心?

剑桥很有意思!在那儿呆过的人常常有这样一种感觉:剑,很锋利!桥,很温柔!剑桥的科技自不必说,牛顿、达尔文、麦克斯韦、爱丁顿......,剑桥的人文却也不让科技,拜伦、培根、…

使用asp.net core web api创建web后台,并连接和使用Sql Server数据库

前言:因为要写一个安卓端app,实现从服务器中获取电影数据,所以需要搭建服务端代码,之前学过C#,所以想用C#实现服务器段代码用于测试,本文使用C#语言,使用asp.net core web api组件搭建服务器端&…

【软考备战·希赛网每日一练】2023年5月9日

文章目录 一、今日成绩二、错题总结第一题三、知识查缺 题目及解析来源:2023年05月09日软件设计师每日一练 一、今日成绩 二、错题总结 第一题 解析: 有损、无损连接判断: (A1,A2)∩(A1,A3)A1 (A1,A2)-(A1,A3)A2 (A1,A3)-(A1,A2)A3 所以A1-&…

车载5G放量增长,哪些厂商抢跑

前装标配19.88万辆,同比上年同期增长724.89%,这是一季度中国市场乘用车5G搭载上车交付的成绩。高工智能汽车研究院监测数据显示,2022年全年5G交付搭载41.74万辆(不含选装),前装搭载率为2.09%。 这意味着&a…

【Linux】GDB多进程调试

目录 GDB多进程调试 GDB多进程调试 演示父子进程如何进行gdb调试会用到hello.c文件 hello.c文件内容如下&#xff1a; #include <stdio.h> #include <unistd.h>int main() {printf("begin\n");if(fork() > 0) {printf("我是父进程&#xff1…

Baumer工业相机堡盟工业相机如何使用BGAPI SDK进行两个万兆网相机的同步采集

Baumer工业相机堡盟工业相机如何使用BGAPI SDK进行两个万兆网相机的同步采集 Baumer工业相机Baumer工业相机图像数据转为Bitmap的技术背景Baumer同步异常 &#xff1a;客户使用两个Baumer万兆网相机进行同步采集发现FrameID相同&#xff0c;但是图像不同步细节原因解决办法 Bau…

Windows下python中的pip换源

在Windows中更换pip数据源方法&#xff0c;提高Python相关包安装效率 1.在windows环境下&#xff0c;打开我的电脑&#xff0c;在"地址栏"输杰沫入: %APPDATA% 后回车 2.在打开的文件夹中新建 pip 文件夹&#xff08;打开的地址为下图所示&#xff09; 3.进入pip文…

在 Python 中将泊松分布拟合到不同的数据集

文章目录 在 Python 中将泊松分布拟合到不同的数据集在 Python 中拟合泊松分布的分箱最小二乘法程序的导入函数为泊松分布创建一个虚拟数据集并使用该数据集绘制直方图使用曲线拟合将曲线拟合到直方图 使用负二项式拟合过度分散的数据集上的泊松分布创建数据集使用数据集绘制直…

JAVA算法(一)查找算法

一、基本查找 / 顺序查找 核心&#xff1a;从0索引开始挨个往后查找 private static boolean basicSearch(int[] arr, int number) {for (int i 0; i < arr.length; i) {if (arr[i] number) {return true;}}return false;}二、二分查找 / 折半查找 前提&#xff1a;数组…

(四) 打造更加智能的即时通信系统——实现主界面消息和联系人切换效果

文章目录 一、引言二、界面设计的基本要求2.1 界面美观简洁2.2 功能合理布局 三、界面布局和控件设计四、效果展示五、关键代码六、个人经验分享6.1 即时通信系统开发中的经验和总结6.2 遇到的问题和解决方案6.3优化即时通信系统 七、总结 一、引言 当今社会&#xff0c;人们对…

解决 scalac: bad option: ‘-make:transitive‘

scalac: bad option: ‘-make:transitive’ 打开项目所在位置并进入 .idea 修改scala_compiler.xml文件 删除掉参数行包含-make:transitive 保存后 重新运行代码

Linux驱动开发笔记(二):ubuntu系统从源码编译安装gcc7.3.0编译器

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/130533941 红胖子网络科技博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬…

uniapp云打包

1. 生成本地打包资源 2. 下载Android Studio和App离线SDK 导航路径&#xff1a;https://nativesupport.dcloud.net.cn/AppDocs/usesdk/android 下载的Android 离线SDK与本地开发工具版本对应 3. 解压得到的目录如下 4. 使用Android Studio打开Android 离线SDK解压目录里面这个…

计算机毕业论文选题推荐|软件工程|系列一

文章目录 导文题目导文 计算机毕业论文选题推荐|软件工程 (***语言)==使用其他任何编程语言 例如:基于(***语言)门窗账务管理系统的设计与实现 得到:基于JAVA门窗账务管理系统的设计与实现 基于vue门窗账务管理系统的设计与实现 等等 题目 基于(***语言)的研发部署管理…

全方位揭秘!大数据从0到1的完美落地之MapReduce实战案例(1)

案例一: MR实战之小文件合并(自定义inputFormat) 项目准备 需求 无论hdfs还是MapReduce&#xff0c;对于小文件都有损效率&#xff0c;实践中&#xff0c;又难免面临处理大量小文件的场景&#xff0c;此时&#xff0c;就需要有相应解决方案 测试数据 分析 小文件的优化无…