- 西安电子科技大学出版社
- 9787560643854
- 165466
- 47189932-8
- 16开
- 288
- 工学
- 软件工程
- TP316
- 自动化技术、计算技术
- 本专科
内容简介
本书是参考教育部颁布的计算机软件专业操作系统教学大纲,结合编者多年积累的教学经验和科研成果,借鉴国内外经典教材的优点编写而成。书中主要介绍了操作系统基本概念、原理和方法,力图体现计算思维、形式化方法和软硬件一体化等基本理念与思维方式在操作系统中的运用。本书可作为高等学校计算机相关专业的本科教材,也可作为相关人员的自学参考书。
目录
第一章 计算机操作系统概论
1.1 操作系统的概念
1.1.1 从用户使用角度理解操作系统
1.1.2 从计算资源管理和控制角度理解操作系统
1.1.3 从计算环境角度理解操作系统
1.2 操作系统的发展历史
1.2.1 串行处理
1.2.2 简单批处理系统
1.2.3 多道程序批处理系统
1.2.4 多道程序设计的实现
1.2.5 分时系统
1.3 操作系统的体系结构
1.3.1 简单结构
1.3.2 层次化结构
1.3.3 微内核结构
1.3.4 模块结构
1.3.5 虚拟机
1.4 操作系统大观
习题
第二章 操作系统的硬件基础
2.1 计算机硬件结构
2.1.1 内存
2.1.2 处理器
2.1.3 I/O模块
2.1.4 系统总线
2.2 指令
2.2.1 指令集
2.2.2 过程调用
2.2.3 CISC和RISC
2.3 指令循环和异常处理
2.3.1 指令循环
2.3.2 异常和带有异常处理的指令循环
2.3.3 异常的分类
2.3.4 异常处理
2.4 处理器的运行模式和模式切换
习题
第三章 进程管理
3.1 进程的概念和结构
3.1.1 程序并发执行的基本需求
3.1.2 进程的概念
3.1.3 进程的结构
3.1.4 进程控制块
3.2 进程的状态
3.2.1 五状态模型
3.2.2 七状态模型
3.3 进程控制
3.3.1 进程的创建和退出
3.3.2 进程切换
3.3.3 进程切换的时机
3.3.4 过程调用和系统调用的区别
3.4 UNIX中的进程控制
3.4.1 获取进程
3.4.2 创建和终止进程
3.4.3 装载和运行程序
3.5 进程调度策略
3.5.1 调度目标
3.5.2 进程调度
3.5.3 短程调度策略
3.6 线程
3.6.1 线程概念的引入
3.6.2 线程的实现
3.6.3 线程与进程的关系
3.6.4 线程的控制
3.6.5 多线程程序中的变量
习题
第四章 进程的并发和死锁
4.1 并发问题
4.2 进程的互斥
4.2.1 互斥问题
4.2.2 解决互斥问题的软件方法
4.2.3 解决互斥问题的硬件方法
4.2.4 信号量和P、V操作
4.2.5 使用信号量解决互斥问题
4.3 进程的同步
4.3.1 同步问题
4.3.2 使用信号量解决同步问题
4.4 典型并发设计问题
4.4.1 生产者-消费者问题
4.4.2 读者-写者问题
4.5 其他并发控制机制
4.5.1 管程
4.5.2 消息传递
4.6 死锁
4.6.1 死锁的定义
4.6.2 哲学家就餐问题
4.6.3 死锁的描述
4.6.4 死锁的条件
4.7 死锁的处理
4.7.1 死锁预防
4.7.2 死锁避免
4.7.3 死锁检测
习题
第五章 内存管理
5.1 内存管理的需求
5.1.1 基本需求
5.1.2 地址定位
5.2 早期操作系统的内存管理
5.2.1 固定分区管理
5.2.2 覆盖技术
5.2.3 可变分区管理
5.2.4 伙伴系统(Buddy system)
5.3 虚拟内存
5.3.1 可执行目标文件
5.3.2 虚拟地址空间
5.3.3 虚拟内存
5.3.4 页表
5.3.5 页面命中和缺页故障
5.3.6 对内存管理需求的支持
5.3.7 地址转换的硬件实现和加速
5.4 分页式虚拟内存管理
5.4.1 程序局部性原理
5.4.2 读取策略
5.4.3 置换策略
5.4.4 驻留集管理
5.4.5 换出策略
5.4.6 加载控制
5.5 分段式虚拟内存管理
5.5.1 基本原理
5.5.2 段的动态链接
5.5.3 段的共享
5.5.4 段页式虚拟内存管理
习题
第六章 文件管理
6.1 文件系统
6.1.1 文件系统的概念
6.1.2 文件系统的存储结构
6.2 文件
6.2.1 文件的属性
6.2.2 文件的操作
6.2.3 文件的类型
6.2.4 文件的存储设备
6.3 文件的结构
6.3.1 文件的逻辑结构
6.3.2 文件的物理结构
6.4 文件存储空间管理
6.4.1 空闲区表
6.4.2 空白块链
6.4.3 位示图
6.4.4 MS-DOS的盘空间管理
6.4.5 UNIX文件存储空间的管理
6.5 文件目录结构
6.5.1 目录结构
6.5.2 目录和目录项的实现
6.5.3 文件链接
6.6 文件共享
6.6.1 打开文件在内核中的数据结构
6.6.2 进程间的文件共享
6.6.3 打开文件的一致性语义和文件锁
6.6.4 管道
6.7 文件系统的保护
6.7.1 文件访问权和保护域
6.7.2 UNIX文件系统的访问控制机制
6.8 UNIX中有关文件的系统调用
6.8.1 文件读、写的系统调用
6.8.2 访问文件状态的系统调用
6.8.3 文件链接的系统调用
习题
第七章 输入/输出系统
7.1 I/O系统概述
7.1.1 I/O系统的基本功能
7.1.2 I/O系统层次结构和模型
7.1.3 I/O系统接口
7.2 I/O系统硬件结构和组织
7.2.1 I/O设备类型
7.2.2 I/O设备的物理特性
7.2.3 I/O设备控制器
7.2.4 I/O通道
7.2.5 I/O设备的控制方式
7.2.6 I/O通道控制方式
7.3 I/O系统软件组织
7.3.1 I/O软件设计的目标
7.3.2 中断处理程序
7.3.3 设备驱动程序
7.3.4 设备无关的I/O软件
7.3.5 用户空间的I/O软件
7.4 缓冲处理技术
7.4.1 缓冲区的引入
7.4.2 单缓冲区和双缓冲区
7.4.3 环形缓冲区
7.4.4 缓冲池
7.5 磁盘驱动调度
7.5.1 磁盘访问时间
7.5.2 早期的磁盘调度算法
7.5.3 基于扫描的磁盘调度算法
7.6 设备分配及其实施
7.6.1 设备分配的数据结构
7.6.2 设备分配的原则
7.6.3 设备分配的策略
7.7 I/O进程控制
7.7.1 I/O控制的功能
7.7.2 I/O控制的实现
7.7.3 设备驱动过程
习题
参考文献
1.1 操作系统的概念
1.1.1 从用户使用角度理解操作系统
1.1.2 从计算资源管理和控制角度理解操作系统
1.1.3 从计算环境角度理解操作系统
1.2 操作系统的发展历史
1.2.1 串行处理
1.2.2 简单批处理系统
1.2.3 多道程序批处理系统
1.2.4 多道程序设计的实现
1.2.5 分时系统
1.3 操作系统的体系结构
1.3.1 简单结构
1.3.2 层次化结构
1.3.3 微内核结构
1.3.4 模块结构
1.3.5 虚拟机
1.4 操作系统大观
习题
第二章 操作系统的硬件基础
2.1 计算机硬件结构
2.1.1 内存
2.1.2 处理器
2.1.3 I/O模块
2.1.4 系统总线
2.2 指令
2.2.1 指令集
2.2.2 过程调用
2.2.3 CISC和RISC
2.3 指令循环和异常处理
2.3.1 指令循环
2.3.2 异常和带有异常处理的指令循环
2.3.3 异常的分类
2.3.4 异常处理
2.4 处理器的运行模式和模式切换
习题
第三章 进程管理
3.1 进程的概念和结构
3.1.1 程序并发执行的基本需求
3.1.2 进程的概念
3.1.3 进程的结构
3.1.4 进程控制块
3.2 进程的状态
3.2.1 五状态模型
3.2.2 七状态模型
3.3 进程控制
3.3.1 进程的创建和退出
3.3.2 进程切换
3.3.3 进程切换的时机
3.3.4 过程调用和系统调用的区别
3.4 UNIX中的进程控制
3.4.1 获取进程
3.4.2 创建和终止进程
3.4.3 装载和运行程序
3.5 进程调度策略
3.5.1 调度目标
3.5.2 进程调度
3.5.3 短程调度策略
3.6 线程
3.6.1 线程概念的引入
3.6.2 线程的实现
3.6.3 线程与进程的关系
3.6.4 线程的控制
3.6.5 多线程程序中的变量
习题
第四章 进程的并发和死锁
4.1 并发问题
4.2 进程的互斥
4.2.1 互斥问题
4.2.2 解决互斥问题的软件方法
4.2.3 解决互斥问题的硬件方法
4.2.4 信号量和P、V操作
4.2.5 使用信号量解决互斥问题
4.3 进程的同步
4.3.1 同步问题
4.3.2 使用信号量解决同步问题
4.4 典型并发设计问题
4.4.1 生产者-消费者问题
4.4.2 读者-写者问题
4.5 其他并发控制机制
4.5.1 管程
4.5.2 消息传递
4.6 死锁
4.6.1 死锁的定义
4.6.2 哲学家就餐问题
4.6.3 死锁的描述
4.6.4 死锁的条件
4.7 死锁的处理
4.7.1 死锁预防
4.7.2 死锁避免
4.7.3 死锁检测
习题
第五章 内存管理
5.1 内存管理的需求
5.1.1 基本需求
5.1.2 地址定位
5.2 早期操作系统的内存管理
5.2.1 固定分区管理
5.2.2 覆盖技术
5.2.3 可变分区管理
5.2.4 伙伴系统(Buddy system)
5.3 虚拟内存
5.3.1 可执行目标文件
5.3.2 虚拟地址空间
5.3.3 虚拟内存
5.3.4 页表
5.3.5 页面命中和缺页故障
5.3.6 对内存管理需求的支持
5.3.7 地址转换的硬件实现和加速
5.4 分页式虚拟内存管理
5.4.1 程序局部性原理
5.4.2 读取策略
5.4.3 置换策略
5.4.4 驻留集管理
5.4.5 换出策略
5.4.6 加载控制
5.5 分段式虚拟内存管理
5.5.1 基本原理
5.5.2 段的动态链接
5.5.3 段的共享
5.5.4 段页式虚拟内存管理
习题
第六章 文件管理
6.1 文件系统
6.1.1 文件系统的概念
6.1.2 文件系统的存储结构
6.2 文件
6.2.1 文件的属性
6.2.2 文件的操作
6.2.3 文件的类型
6.2.4 文件的存储设备
6.3 文件的结构
6.3.1 文件的逻辑结构
6.3.2 文件的物理结构
6.4 文件存储空间管理
6.4.1 空闲区表
6.4.2 空白块链
6.4.3 位示图
6.4.4 MS-DOS的盘空间管理
6.4.5 UNIX文件存储空间的管理
6.5 文件目录结构
6.5.1 目录结构
6.5.2 目录和目录项的实现
6.5.3 文件链接
6.6 文件共享
6.6.1 打开文件在内核中的数据结构
6.6.2 进程间的文件共享
6.6.3 打开文件的一致性语义和文件锁
6.6.4 管道
6.7 文件系统的保护
6.7.1 文件访问权和保护域
6.7.2 UNIX文件系统的访问控制机制
6.8 UNIX中有关文件的系统调用
6.8.1 文件读、写的系统调用
6.8.2 访问文件状态的系统调用
6.8.3 文件链接的系统调用
习题
第七章 输入/输出系统
7.1 I/O系统概述
7.1.1 I/O系统的基本功能
7.1.2 I/O系统层次结构和模型
7.1.3 I/O系统接口
7.2 I/O系统硬件结构和组织
7.2.1 I/O设备类型
7.2.2 I/O设备的物理特性
7.2.3 I/O设备控制器
7.2.4 I/O通道
7.2.5 I/O设备的控制方式
7.2.6 I/O通道控制方式
7.3 I/O系统软件组织
7.3.1 I/O软件设计的目标
7.3.2 中断处理程序
7.3.3 设备驱动程序
7.3.4 设备无关的I/O软件
7.3.5 用户空间的I/O软件
7.4 缓冲处理技术
7.4.1 缓冲区的引入
7.4.2 单缓冲区和双缓冲区
7.4.3 环形缓冲区
7.4.4 缓冲池
7.5 磁盘驱动调度
7.5.1 磁盘访问时间
7.5.2 早期的磁盘调度算法
7.5.3 基于扫描的磁盘调度算法
7.6 设备分配及其实施
7.6.1 设备分配的数据结构
7.6.2 设备分配的原则
7.6.3 设备分配的策略
7.7 I/O进程控制
7.7.1 I/O控制的功能
7.7.2 I/O控制的实现
7.7.3 设备驱动过程
习题
参考文献