1.操作系统管理硬件
操作系统的两个功能:
(1)防止硬件被失控的应用程序滥用
(2)向应用程序提供简单一致的机制来控制复杂而又不大相同的低级硬件设备
2.进程
进程是计算机科学中最重要和最成功的概念之一。
进程是操作系统对一个正在运行的程序的一种抽象。
每个进程好像在独占的使用硬件,而并发运行,则是一个进程与另一个进程的指令是交错执行的。
从一个进程到另一个进程的转换是由操作系统内核(kernel)管理的,如下图,
3.线程
一个进程实际上可以由多个称为线程的执行单元组成,每个线程都运行在进程的上下文中,并共享同样的代码和全局数据。
多线程比多进程更容易共享数据,所以更高效;如果有多处理器可用时,多线程可以使程序运行的更快。
4.虚拟内存
虚拟内存是一个抽象概念,它为每个进程提供一个假象,即每个进程都独占地使用主存(每个进程看到的内存都是一致的,称为虚拟地址空间),如下图,图中的地址是由下往上递增的,
-->程序代码和数据:直接按照可执行目标文件的内容初始化的,在进程一开始运行时就被指定了大小
-->堆:与代码和数据区不同,当调用C标准库函数时,堆可以在运行时动态地扩展和收缩
-->共享库:存放像C标准库和数学库这样的共享库的代码和数据的区域
-->栈:位于用户虚拟地址空间顶部的是用户栈,编译器用它来实现函数调用。和堆一样,用户栈在程序执行期间可以动态地扩展和收缩
-->内核虚拟内存:地址空间顶部的区域是为内核保留的,不允许应用程序读写这个区域的内容或者直接调用内核代码定义的函数,相反,它们必须调用内核来执行这些操作
虚拟内存的基本思想是把一个进程虚拟内存的内容存储在磁盘上,然后用主存作为磁盘的高速缓存。
5.文件
文件就是字节序列,仅此而已。
每个I/O设备,包括磁盘、键盘、显示器,甚至网络,都可以看成是文件。
文件这个简单而精致的概念是非常强大的,因为它向应用程序提供了一个统一的视图。
6.并发和并行
并发:一个同时具有多个活动的系统
并行:指的是用并发来使一个系统运行的更快,并行可以在计算机系统的多个抽象层次上运行
以下是按照系统层次结构中由高到低的顺序重点介绍,
-->线程级并发
对于单核处理器,线程级并发是通过交错执行指令实现的;
对于多核处理器(多个cpu集成到一个集成电路芯片上),每个核都有自己的L1/L2高速缓存,可以实现超线程(同时多线程),如下图,
-->指令集并行
在较低的抽象层次上,现代处理器可以同时执行多条指令的属性称为指令级并行
如果处理器可以达到比一个周期一条指令更快的执行效率,就称之为超标量处理器,大多数现代处理器都支持超标量操作。
-->单指令、多数据并行
在最低层次上,许多现代处理器拥有特殊的硬件,允许一条指令产生多个可以并行执行的操作,这种方式称为单指令、多数据,即SIMD并行。
例如,较新几代的intel和AMD处理器都具有并行地对8对单精度浮点数做加法的指令。
提供这些SIMD指令多是为了提高处理影像、声音和视频应用数据的执行速度,虽然有些编译器会试图从C程序中自动抽取SIMD并行性,但是更可靠的方法是用编译器支持的特殊的向量数据类型来写程序,比如GCC就支持向量数据类型。
第一章小结