操作系统对程序提供服务的方法

操作系统管理硬件

回到hello程序的例子,外壳(shell)没有直接访问磁盘,hello程序也没有直接访问显示器。取而代之的是,它们都是依靠操作系统提供的服务来达到的上述功能。我们可以把操作系统看成是应用程序和硬件之间插入的一层软件,所有应用程序对硬件的操作都必须通过操作系统。
计算机系统的分层视图
操作系统有两个基本功能:

  1. 防止硬件被失控的应用程序滥用
  2. 向程序提供简单一致的机制来控制复杂而又通常大相径庭的低级硬件设备

操作系统通过几个基本的抽象概念(进程、虚拟存储器和文件)来实现这两个功能
操作系统提供的抽象表示
如图所示,文件是对I/O设备的抽象表示,虚拟存储器是对主存和磁盘I/O设备的抽象表示,进程则是对处理器,主存和I/O设备的抽象表示。

1 进程

进程是操作系统对一个正在运行的程序的一种抽象, 使得就好像系统上只有这一个程序在运行,只有这一个程序在使用处理器、主存和I/O设备,处理器看上去就像在不间断地一条接一条的执行程序中的指令,即该程序的代码和数据是系统存储器中唯一的对象。
一个系统上可以同时运行多个进程,而每个进程都好像在独占地使用硬件,无论是单核还是多核系统,一个CPU看上去都像是在并发执行多个进程,并发运行的意思是一个进程的指令和另一个进程的指令是交错执行的。这通过处理器在进程间切换来实现。
操作系统实现这种交错执行的机制称为上下文切换。 操作系统保持跟踪进程运行所需的所有状态信息。这种状态(上下文)包括许多信息,比如PC和寄存器文件的当前值,以及主存的内容。在任何一个时刻,单处理器系统都只能执行一个进程的代码。当操作系统决定要把控制权从当前进程转移到某个新进程时,就会进行上下文切换(保存当前进程上下文,恢复新进程的上下文,然后把控制权传递到新进程,新进程从上次停止的地方开始)
进程的上下文切换
上图为两个并发的进程:shell进程和hello进程,最初,只有shell进程在运行,即等待命令行上的输入,当我们让它运行hello程序时,shell通过调用一个专门的函数,即系统调用,来执行我们的请求,系统调用会将控制权传递给操作系统。操作系统保存shell的上下文,然后将控制权传递给新的hello进程。hello进程终止后,操作系统恢复shell的上下文,并将控制权传回给它,shell将继续等待下一个命令行的输入。

2 线程

一个进程实际上可以由多个称为线程的执行单元组成,每个线程都运行在进程的上下文中,并共享同样的代码和全局数据。 由于网络服务器对并行处理的需求,线程称为越来越重要的编程模型,因为多线程之间比多进程之间更容易共享数据,也因为线程一般来说都比进程更高效。 当有多处理器可用的时候,多线程也是一种使程序可以更快运行的方法。

3 虚拟存储器

虚拟存储器是一个抽象概念,它为每个进程提供了一个假象,即每个进程都在独占的使用主存。每个进程看到的是一致的存储器,称为虚拟地址空间。 在Linux中,地址空间最上面的区域是为操作系统中的代码和数据保留的,这对所有进程来说都是一样的。地址空间的底部区域存放用户进程定义的代码和数据。注意:图中的地址是从下往上增大的。
进程的虚拟地址空间

每个进程看到的虚拟地址空间有大量准确定义的区构成,每个区都有专门的功能。 现在先从最低的地址开始,逐步向上地简单了解一下每一个区。

  • 程序代码和数据:
    对于所有的进程来说,代码是从同一固定地址开始,紧接着的是和C全局变量相对应的数据位置。代码和数据区是直接按照可执行目标文件的内容初始化的。,在实例中就是可执行文件hello。
  • 堆:
    代码和数据区后紧随着的是运行时堆。代码和数据区是在进程一开始运行时就被规定了大小,n与此不同,当调用如melloc和free这样的C标准库函数时,堆可以在运行时动态地扩展和收缩。
  • 共享库:
    大约在地址空间的中间部分是一块用来存放像C标准库和数学库这样共享库的代码和数据的区域。
  • 栈:
    位于用户虚拟地址空间顶部的是用户栈,编译器用它来实现函数调用。和堆一样,用户栈在程序执行期间e可以动态地扩展和收缩,特别是每次我们调用一个函数时,栈就会增长:从一个函数返回时,栈就会收缩。
  • 内核虚拟存储器:
    内核总是驻留在内存中,是操作系统的一部分。地址空间顶部的区域是为内核保留的,不允许应用程序读写这个区域的内容或者直接调用内核代码定义的函数。

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

4 文件

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

深入理解计算机系统笔记:

  1. 计算机中信息的表示
  2. 计算机中信息的表示和处理
  3. 程序从源代码到可执行文件的整个过程
  4. 可执行文件运行的底层原理
  5. 操作系统对程序提供服务的方法
  6. 网络通信
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值