《计算机操作系统》PDF下载

  • 购买积分:14 如何计算积分?
  • 作  者:何炎祥等编著
  • 出 版 社:北京:清华大学出版社
  • 出版年份:2004
  • ISBN:7302077797
  • 页数:412 页
图书介绍:本书详细介绍了现代计算机操作系统设计的基本概念,基本原理和典型实现技术,着重讲述了构造操作系统过程中所面临的问题和解决方法,并且讨论了操作系统的最新进展,包括线程、网格操作系统等。

第1章 操作系统概论 1

1.1 操作系统的作用 1

1.1.1 硬件系统和应用程序间的界面 1

目录 1

1.1.2 资源管理者 2

1.1.3 推动操作系统发展的因素 3

1.2.1 串行处理系统 4

1.2.2 简单批处理系统 4

1.2 操作系统的演变 4

1.2.3 多道程序批处理系统 7

1.2.4 分时系统 9

1.2.5 实时系统 11

1.3 操作系统的主要成就 12

1.3.1 进程 12

1.3.2 存储管理 15

1.3.3 信息保护和安全性 16

1.3.4 调度和资源管理 17

1.3.5 系统结构 18

1.4 操作系统举例 20

1.4.1 Windows NT 20

1.4.2 UNIX System V 23

1.4.3 MVS 24

1.5 操作系统的主要研究课题 28

小结 28

习题 28

2.1 进程状态 30

第2章 进程描述与控制 30

2.1.1 进程产生和终止 32

2.1.2 进程状态模型 34

2.1.3 进程挂起 38

2.2 进程描述 42

2.2.1 操作系统控制结构 43

2.2.2 进程控制结构 44

2.2.3 进程属性 44

2.3.2 进程创建 47

2.3.1 执行模式 47

2.3 进程控制 47

2.3.3 进程切换 48

2.3.4 上下文切换 49

2.3.5 操作系统的运行 49

2.3.6 微核 51

2.4 线程和SMP 51

2.4.1 线程及其管理 51

2.4.2 多线程的实现 53

2.4.4 SMP 55

2.4.3 进程与线程的关系 55

2.5 系统举例 57

2.5.1 UNIX System V 57

2.5.2 Windows NT 60

2.5.3 MVS 65

2.5.4 Linux 67

小结 69

习题 69

第3章 并发控制——互斥与同步 72

3.1 并发原理 73

3.1.1 进程间的相互作用 75

3.1.2 进程间的相互竞争 76

3.1.3 进程间的相互合作 78

3.1.4 互斥的要求 79

3.2 互斥——软件解决方法 79

3.2.1 Dekker算法 79

3.2.2 Peterson算法 83

3.3.1 禁止中断 84

3.3 互斥——硬件解决方法 84

3.3.2 使用机器指令 85

3.4 信号量 87

3.4.1 用信号量解决互斥问题 89

3.4.2 用信号量解决生产者/消费者问题 90

3.4.3 信号量的实现 94

3.4.4 用信号量解决理发店问题 94

3.5 管程 98

3.5.1 带信号量的管程 98

3.5.2 用管程解决生产者/消费者问题 100

3.6 消息传递 101

3.6.1 消息传递原语 101

3.6.2 用消息传递实现同步 102

3.6.3 寻址方式 103

3.6.4 消息格式 104

3.6.5 排队规则 104

3.6.6 用消息传递实现互斥 104

3.7.1 读者优先 106

3.7 读者/写者问题 106

3.7.2 写者优先 107

3.8 系统举例 110

3.8.1 UNIX System V 110

3.8.2 Windows NT 112

3.8.3 MVS 113

小结 115

习题 115

4.1.1 可重用资源 118

4.1 死锁问题概述 118

第4章 死锁处理 118

4.1.2 消耗型资源 119

4.1.3 产生死锁的条件 121

4.2 死锁处理 121

4.2.1 死锁预防 121

4.2.2 死锁避免 122

4.2.3 死锁检测 126

4.2.4 死锁恢复 127

4.2.5 处理死锁的综合方法 128

4.3 哲学家用餐问题 129

小结 130

习题 130

第5章 内存管理 132

5.1 概述 132

5.1.1 基本概念 132

5.1.2 虚拟存储器 134

5.1.3 重定位 135

5.2.1 分区法 137

5.2 存储管理的基本技术 137

5.2.2 可重定位分区法 139

5.2.3 覆盖技术 141

5.2.4 交换技术 142

5.3 分页存储管理 143

5.3.1 基本概念 143

5.3.2 纯分页系统 146

5.3.3 请求式分页系统 148

5.3.4 硬件支持及缺页处理 148

5.3.5 页的共享和保护 150

5.4 分段存储管理 151

5.4.1 基本概念 151

5.4.2 基本原理 152

5.4.3 硬件支持和缺段处理 152

5.4.4 段的共享和保护 154

5.5 段页式存储管理 156

5.5.1 基本概念 156

5.5.2 地址转换 157

5.6 虚拟内存的置换算法 158

5.5.3 管理算法 158

5.6.1 先进先出页面置换算法 159

5.6.2 最佳页面置换算法 159

5.6.3 最近最少使用页面置换算法 160

5.6.4 第2次机会页面置换算法 161

5.6.5 时钟页面置换算法 161

5.6.6 其他页面置换算法 162

5.7 系统举例 163

5.7.1 UNIX系统中的存储管理技术 163

5.7.2 Linux系统中的存储管理技术 167

小结 168

习题 169

第6章 处理机调度 170

6.1 调度类型 170

6.1.1 长程调度 172

6.1.2 中程调度 172

6.1.3 短程调度 172

6.2.1 短程调度标准 173

6.2 调度算法 173

6.2.2 优先权的使用 174

6.2.3 调度策略 175

6.2.4 性能比较 183

6.2.5 模拟模型 185

6.2.6 公平分享调度策略 186

6.3 多处理机调度 188

6.3.1 粒度 189

6.3.2 设计要点 190

6.3.3 调度策略 191

6.4 实时调度 196

6.4.1 实时操作系统的特性 196

6.4.2 实时调度 199

6.4.3 期限调度 200

6.4.4 比率单调调度 203

6.5 响应时间 205

6.6.1 UNIX System V 206

6.6 系统举例 206

6.6.2 Windows NT 207

6.6.3 MVS 209

小结 210

习题 210

第7章 I/O设备管理 213

7.1 I/O系统硬件 213

7.1.1 I/O设备 213

7.1.2 设备控制器 214

7.1.3 I/O技术 216

7.2 I/O软件 222

7.2.1 中断处理程序 222

7.2.2 设备驱动程序 223

7.2.3 与设备无关的I/O软件 224

7.2.4 用户空间的I/O软件 226

7.2.5 缓冲技术 227

7.3 磁盘调度 232

7.3.1 调度策略 232

7.3.2 磁盘高速缓存 236

7.4 系统举例 238

7.4.1 UNIX System V 238

7.4.2 Windows NTI/O分析 240

小结 244

习题 245

第8章 文件管理 247

8.1 文件与文件系统 247

8.1.1 文件及其分类 247

8.1.2 文件系统及其功能 249

8.2 文件的结构及其存取方式 250

8.2.1 文件的逻辑结构及其存取方式 250

8.2.2 文件的物理结构及其存储设备 252

8.3 文件管理 258

8.3.1 文件目录结构 258

8.3.2 文件目录管理 264

8.4 文件存储空间的分配与管理 265

8.4.1 文件存储空间的分配 265

8.4.2 磁盘空间管理 267

8.5.1 PE可移动执行的文件格式 270

8.5 系统举例——Windows NT 270

8.5.2 PE文件首部 272

8.5.3 块表数据结构及辅助信息块 275

小结 277

习题 277

9.1 客户/服务器模式 278

9.1.1 客户/服务器模式的概念 278

第9章 分布计算 278

9.1.2 客户/服务器模式的应用 280

9.1.3 中间件 283

9.2 分布式消息传递 285

9.2.1 分布式消息传递的方法 285

9.2.2 分布式消息传递的可靠性 286

9.3 远程过程调用 286

小结 288

习题 289

10.1 进程迁移 290

10.1.1 进程迁移的原因 290

第10章 分布式进程管理 290

10.1.2 进程迁移的机制 291

10.1.3 进程迁移的协商 293

10.1.4 进程驱逐 294

10.1.5 抢占及非抢占进程的迁移 295

10.2 分布式全局状态 295

10.2.1 全局状态及分布式快照 295

10.2.2 分布式快照算法 297

10.3.1 分布式互斥问题 299

10.3 分布式进程管理——互斥 299

10.3.2 分布式系统的事件定序——时戳方法 301

10.3.3 分布式互斥算法 302

10.4 分布式死锁处理 306

10.4.1 资源分配中的死锁 307

10.4.2 死锁预防 307

10.4.3 死锁避免 309

10.4.4 死锁检测 309

10.4.5 消息通信中的死锁 312

小结 314

习题 315

第11章 操作系统的安全性 316

11.1 安全性概述 316

11.1.1 安全性的内涵 316

11.1.2 操作系统的安全性 317

11.1.3 操作系统的安全性级别 320

11.2 安全保护机制 321

11.2.1 进程支持 321

11.2.2 内存及地址保护 322

11.2.3 存取控制 325

11.2.4 文件保护 329

11.2.5 用户身份鉴别 331

11.3 病毒及其防御 334

11.3.1 病毒概述 334

11.3.2 病毒的防御机制 335

11.3.3 特洛伊木马程序及其防御 336

11.4 加密技术 337

11.4.1 传统加密方法 337

11.4.2 公开密钥加密方法 338

11.4.3 密钥的管理 339

11.5 安全操作系统的设计 341

11.5.1 安全模型 342

11.5.2 安全操作系统的设计策略 344

11.6 系统举例——Windows2000的安全性分析 348

小结 350

习题 351

第12章 网格操作系统的一个雏形——Globus 353

12.1.1 网格的特点 355

12.1 网格简介 355

12.1.2 网格的体系结构 356

12.1.3 网格技术 361

12.2 Globus初探 362

12.2.1 Globus工具包 363

12.2.2 Globus与5层沙漏模型 369

12.2.3 Globus与OGSA模型 370

小结 372

习题 373

13.1.1 MINIX的组成结构 374

第13章 一个小型操作系统的实现 374

13.1 MINIX概述 374

13.1.2 头文件 377

13.2 进程 379

13.2.1 概述 379

13.2.2 具体实现 381

13.3 I/O任务 387

13.3.1 I/O任务概述 387

13.3.2 设备驱动程序的实现 389

13.4.1 内存管理概述 393

13.4 内存管理 393

13.4.2 实现 396

13.5 文件系统 400

13.5.1 文件系统概述 400

13.5.2 实现 403

小结 407

习题 408

词汇索引 409