第0章 读者指南 1
0.1 本书概述 1
0.2 主题顺序 1
0.3 因特网和Web资源 2
第一部分 背景 5
第1章 计算机系统概述 6
1.1 基本构成 6
1.2 处理器寄存器 6
1.2.1 用户可见寄存器 7
1.2.2 控制和状态寄存器 8
1.3 指令的执行 9
1.3.1 取指令和执行指令 9
1.3.2 I/O函数 11
1.4 中断 11
1.4.1 中断和指令周期 13
1.4.2 中断处理 14
1.4.3 多个中断 16
1.4.4 多道程序设计 18
1.5 存储器的层次结构 19
1.6 高速缓冲存储器 21
1.6.1 动机 22
1.6.2 高速缓冲存储器原理 22
1.6.3 高速缓冲存储器设计 24
1.7 I/O通信技术 24
1.7.1 可编程I/O 25
1.7.2 中断驱动I/O 25
1.7.3 直接存储器访问 26
1.8 推荐读物和网站 27
1.9 关键术语、复习题和习题 27
附录1A 两级存储器的性能特征 29
附录1B 过程控制 34
第2章 操作系统概述 38
2.1 操作系统的目标和功能 38
2.1.1 作为用户/计算机接口的操作系统 38
2.1.2 作为资源管理器的操作系统 39
2.1.3 操作系统的易扩展性 40
2.2 操作系统的发展 41
2.2.1 串行处理 41
2.2.2 简单批处理系统 42
2.2.3 多道程序批处理系统 44
2.2.4 分时系统 46
2.3 主要的成就 48
2.3.1 进程 48
2.3.2 内存管理 51
2.3.3 信息保护和安全 52
2.3.4 调度和资源管理 53
2.3.5 系统结构 54
2.4 现代操作系统的特征 57
2.5 Microsoft Windows概述 59
2.5.1 历史 59
2.5.2 单用户多任务 60
2.5.3 体系结构 61
2.5.4 客户/服务器模型 64
2.5.5 线程和SMP 65
2.5.6 Windows对象 65
2.6 传统的UNIX系统 66
2.6.1 历史 66
2.6.2 描述 67
2.7 现代UNIX系统 68
2.7.1 系统V版本4(简称SVR4) 68
2.8.1 历史 69
2.8 Linux操作系统 69
2.7.3 4.4BSD 69
2.7.2 Solaris 9 69
2.8.2 模块结构 70
2.8.3 内核组件 72
2.9 推荐读物和网站 74
2.10 关键术语、复习题和习题 75
第二部分 进程 77
第3章 进程描述和控制 79
3.1 什么是进程 79
3.1.1 背景 79
3.2 进程和进程控制块 80
3.3 进程状态 81
3.3.1 两状态进程模型 83
3.3.2 进程的创建和终止 83
3.3.3 五状态模型 84
3.3.4 被挂起的进程 87
3.4 进程描述 92
3.4.1 操作系统的控制结构 92
3.4.2 进程控制结构 93
3.5 进程控制 98
3.5.1 执行模式 98
3.5.2 进程创建 99
3.5.3 进程切换 99
3.5.4 操作系统的执行 101
3.6 UNIX SVR4进程管理 103
3.6.1 进程状态 103
3.6.2 进程描述 105
3.6.3 进程控制 106
3.7 小结 107
3.8 推荐读物 107
3.9 关键术语、复习题和习题 107
编程项目1:开发一个shell程序 110
第4章 线程、对称多处理和微内核 112
4.1 进程和线程 112
4.1.1 多线程 112
4.1.2 线程功能特性 115
4.1.3 例子——Adobe PageMaker 116
4.1.4 用户级和内核级线程 118
4.1.5 其他方案 121
4.2 对称多处理 122
4.2.1 SMP系统的体系结构 123
4.2.2 SMP系统的组织结构 124
4.2.3 多处理器操作系统的设计思考 125
4.3 微内核 125
4.3.1 微内核体系结构 125
4.3.2 微内核组织结构的优点 126
4.3.3 微内核性能 127
4.3.4 微内核设计 128
4.4 Windows线程和SMP管理 130
4.4.1 进程对象和线程对象 131
4.4.2 多线程 132
4.4.3 线程状态 132
4.4.4 对OS子系统的支持 133
4.4.5 对称多处理的支持 134
4.5 Solaris线程和SMP管理 134
4.5.1 多线程体系结构 134
4.5.2 动机 135
4.5.3 进程结构 136
4.5.4 线程的执行 137
4.5.5 把中断当做线程 138
4.6 Linux的进程和线程管理 138
4.6.1 Linux任务 138
4.6.2 Linux线程 140
4.8 推荐读物 141
4.7 小结 141
4.9 关键术语、复习题和习题 142
第5章 并发性:互斥和同步 144
5.1 并发的原理 145
5.1.1 一个简单的例子 145
5.1.2 竞争条件 147
5.1.3 操作系统关注的问题 147
5.1.4 进程的交互 148
5.1.5 互斥的要求 150
5.2 互斥:硬件的支持 151
5.2.1 中断禁用 151
5.2.2 专用机器指令 151
5.3 信号量 154
5.3.1 互斥 156
5.3.2 生产者/消费者问题 158
5.3.3 信号量的实现 162
5.4.1 使用信号的管程 163
5.4 管程 163
5.4.2 使用通知和广播的管程 166
5.5 消息传递 168
5.5.1 同步 168
5.5.2 寻址 169
5.5.3 消息格式 170
5.5.4 排队原则 171
5.5.5 互斥 171
5.6 读者-写者问题 172
5.6.1 读进程具有优先权 173
5.6.2 写进程具有优先权 174
5.7 小结 176
5.8 推荐读物 176
5.9 关键术语、复习题和习题 177
6.1 死锁原理 183
第6章 并发性:死锁和饥饿 183
6.1.1 可重用资源 185
6.1.2 可消费资源 187
6.1.3 资源分配图 187
6.1.4 死锁的条件 188
6.2 死锁预防 189
6.2.1 互斥 189
6.2.2 占有且等待 190
6.2.3 非抢占 190
6.2.4 循环等待 190
6.3 死锁避免 190
6.3.1 进程启动拒绝 191
6.3.2 资源分配拒绝 191
6.4 死锁检测 195
6.4.1 死锁检测算法 195
6.5 一种综合的死锁策略 196
6.4.2 恢复 196
6.6 哲学家就餐问题 197
6.6.1 使用信号量解决方案 198
6.6.2 使用管程解决方案 198
6.7 UNIX的并发机制 200
6.7.1 管道 200
6.7.2 消息 200
6.7.3 共享存储区 200
6.7.4 信号量 200
6.7.5 信号 201
6.8 Linux内核并发机制 202
6.8.1 原子操作 202
6.8.2 自旋锁 203
6.8.3 信号量 204
6.8.4 屏障 206
6.9 Solaris线程同步原语 207
6.9.1 互斥锁 207
6.9.2 信号量 208
6.9.3 多读者单写者锁 208
6.9.4 条件变量 208
6.10 Windows并发机制 209
6.10.1 等待函数 209
6.10.2 同步对象 209
6.10.3 临界区对象 210
6.11 小结 210
6.12 推荐读物 211
6.13 关键术语、复习题和习题 211
第三部分 内存 217
7.1.1 重定位 218
7.1 内存管理的需求 218
第7章 内存管理 218
7.1.2 保护 219
7.1.3 共享 219
7.1.4 逻辑组织 219
7.1.5 物理组织 220
7.2 内存分区 220
7.2.1 固定分区 220
7.2.2 动态分区 223
7.2.3 伙伴系统 225
7.2.4 重定位 227
7.3 分页 228
7.4 分段 231
7.5 小结 232
7.6 推荐读物 232
7.7 关键术语、复习题和习题 233
附录7A 加载和链接 235
第8章 虚拟内存 239
8.1 硬件和控制结构 239
8.1.1 局部性和虚拟内存 240
8.1.2 分页 241
8.1.3 分段 250
8.1.4 分段和分页的结合 251
8.1.5 保护和共享 252
8.2 操作系统软件 253
8.2.1 读取策略 253
8.2.2 放置策略 254
8.2.3 替换策略 254
8.2.4 驻留集管理 260
8.2.5 清除策略 264
8.2.6 加载控制 265
8.3.1 分页系统 266
8.3 UNIX和Solaris内存管理 266
8.3.2 内核内存分配器 269
8.4 Linux内存管理 270
8.4.1 Linux虚拟内存 270
8.4.2 内核内存分配 271
8.5 Windows内存管理 272
8.5.1 Windows虚拟地址映射 272
8.5.2 Windows分页 273
8.6 小结 273
8.7 推荐读物和网站 274
8.8 关键术语、复习题和习题 275
附录8A 哈希表 278
第四部分 调度 281
第9章 单处理器调度 282
9.1 处理器调度的类型 282
9.1.1 长程调度 283
9.1.2 中程调度 284
9.2 调度算法 285
9.2.1 短程调度准则 285
9.1.3 短程调度 285
9.2.2 优先级的使用 286
9.2.3 选择调度策略 286
9.2.4 性能比较 296
9.2.5 公平共享调度 299
9.3 传统的UNIX调度 302
9.4 小结 303
9.5 推荐读物 304
9.6 关键术语、复习题和习题 304
附录9A 响应时间 307
附录9B 排队系统 308
编程项目2:主机调度shell程序 312
10.1.1 粒度 317
第10章 多处理器和实时调度 317
10.1 多处理器调度 317
10.1.2 设计问题 318
10.1.3 进程调度 320
10.1.4 线程调度 320
10.2 实时调度 325
10.2.1 背景 325
10.2.2 实时操作系统的特点 326
10.2.3 实时调度 329
10.2.4 时限调度 329
10.2.5 速率单调调度 332
10.2.6 优先级逆转 335
10.3 Linux调度 337
10.3.1 实时调度 337
10.3.2 非实时调度 338
10.4 UNIX SVR4调度 340
10.5.1 进程和线程优先级 341
10.5 Windows调度 341
10.5.2 多处理器调度 342
10.6 小结 343
10.7 推荐读物 343
10.8 关键术语、复习题和习题 344
第五部分 输入/输出和文件 347
第11章 I/O管理和磁盘调度 348
11.1 I/O设备 348
11.2 I/O功能的组织 349
11.2.1 I/O功能的发展 350
11.2.2 直接存储器访问 350
11.3.1 设计目标 352
11.3.2 I/O功能的逻辑结构 352
11.3 操作系统设计问题 352
11.4 I/O缓冲 354
11.4.1 单缓冲区 354
11.4.2 双缓冲 356
11.4.3 循环缓冲 356
11.4.4 缓冲的用途 356
11.5 磁盘调度 356
11.5.1 磁盘性能参数 357
11.5.2 磁盘调度策略 359
11.6 RAID 362
11.6.1 RAID第0层 365
11.6.2 RAID第1层 365
11.6.3 RAID第2层 366
11.6.4 RAID第3层 366
11.6.5 RAID第4层 367
11.6.7 RAID第6层 368
11.7 磁盘高速缓冲 368
11.6.6 RAID第5层 368
11.7.1 设计考虑 369
11.7.2 性能考虑 370
11.8 UNIX SVR4 I/O 370
11.8.1 缓冲区高速缓存 372
11.8.2 字符队列 373
11.8.2 无缓冲I/O 373
11.8.3 UNIX设备 373
11.9 LINUX I/O 374
11.9.1 磁盘调度 374
11.9.2 Linux页面缓存 376
11.10 Windows I/O 376
11.10.1 基本I/O模块 376
11.11 小结 377
11.10.3 软件RAID 377
11.10.2 异步I/O和同步I/O 377
11.12 推荐读物和网站 378
11.13 关键术语、复习题和习题 379
附录11A 磁盘存储设备 381
第12章 文件管理 387
12.1 概述 387
12.1.1 文件和文件系统 387
12.1.2 文件结构 388
12.1.3 文件管理系统 389
12.2 文件组织和访问 391
12.2.1 堆 393
12.2.2 顺序文件 393
12.2.3 索引顺序文件 394
12.2.4 索引文件 394
12.3.2 结构 395
12.3.1 内容 395
12.3 文件目录 395
12.2.5 直接文件或散列文件 395
12.3.3 命名 397
12.4 文件共享 398
12.4.1 访问权限 398
12.4.2 同时访问 399
12.5 记录组块 399
12.6 二级存储管理 401
12.6.1 文件分配 401
12.6.2 空闲空间的管理 404
12.6.3 可靠性 406
12.7 UNIX文件管理 407
12.7.1 索引节点 407
12.7.2 文件分配 408
12.7.3 目录 409
12.8 Linux虚拟文件系统 410
12.7.4 卷结构 410
12.8.1 超级块对象 412
12.8.2 索引节点对象 413
12.8.3 目录项对象 413
12.8.4 文件对象 413
12.9 Windows文件系统 413
12.9.1 NTFS的重要特征 413
12.9.2 NTFS卷和文件结构 414
12.9.3 可恢复性 416
12.10 小结 417
12.11 推荐读物 417
12.12 关键术语、复习题和习题 418
第六部分 分布式系统和安全 421
第13章 网络 424
13.1 为什么需要网络体系结构 425
13.2 TCP/IP协议体系结构 426
13.2.2 TCP与UDP 427
13.2.1 TCP/IP层 427
13.2.3 IP和IPv6 428
13.2.3 TCP/IP操作过程 429
13.2.4 TCP/IP应用程序 431
13.3 套接字 432
13.3.1 套接字 432
13.3.2 套接字接口调用 433
13.4 Linux网络 434
13.4.1 发送数据 435
13.4.2 接收数据 436
13.5 小结 436
13.6 推荐读物和网站 437
13.7 关键术语、复习题和习题 437
附录13A 简单文件传输协议 439
14.1 客户/服务器计算模型 443
14.1.1 什么是客户/服务器计算模型 443
第14章 分布式处理、客户/服务器和集群 443
14.1.2 客户/服务模型的应用 444
14.1.3 中间件 449
14.2 分布式消息传递 451
14.2.1 可靠性与不可靠性 452
14.2.2 阻塞与无阻塞 453
14.3 远程过程调用 453
14.3.2 参数表示 454
14.3.1 参数传递 454
14.3.3 客户/服务器绑定 455
14.3.4 同步和异步 455
14.3.5 面向对象机制 455
14.4 集群 456
14.4.1 集群的配置 456
14.4.2 操作系统的设计问题 458
14.4.3 集群计算机的体系结构 459
14.5 Windows集群服务器 460
14.4.4 集群与SMP 460
14.6 Sun集群 461
14.6.1 对象和通信支持 462
14.6.2 进程管理 462
14.6.3 网络连接 462
14.6.4 全局文件系统 463
14.7 Beowulf和Linux集群 464
14.7.1 Beowulf特征 464
14.7.2 Beowulf软件 465
14.8 小结 465
14.9 推荐读物和网站 466
14.10 关键术语、复习题和习题 467
15.1.1 动机 469
15.1.2 进程迁移机制 469
第15章 分布式进程管理 469
15.1 进程迁移 469
15.1.3 迁移协商 472
15.1.4 移出 473
15.1.5 抢占式转移和非抢占式转移 474
15.2 分布式全局状态 474
15.2.1 全局状态和分布式快照 474
15.2.2 分布式快照算法 476
15.3.1 分布式互斥概念 478
15.3 分布式互斥 478
15.3.2 分布式系统中的事件排序 480
15.3.3 分布式队列 482
15.3.4 令牌传递方法 484
15.4 分布式死锁 486
15.4.1 资源分配中的死锁 486
15.4.2 消息通信中的死锁 490
15.6 推荐读物 493
15.5 小结 493
15.7 关键术语、复习题和习题 494
第16章 安全 495
16.1 安全威胁 495
16.1.1 威胁的类型 496
16.1.2 计算机系统资产 496
16.2 保护 500
16.2.1 内存的保护 501
16.2.2 面向用户的访问控制 501
16.2.3 面向数据的访问控制 502
16.3 入侵者 503
16.3.1 入侵技术 504
16.3.2 口令保护 505
16.3.3 口令选择策略 509
16.3.4 入侵检测 510
16.4.1 恶意程序 512
16.4 恶意软件 512
16.4.2 病毒的本质 515
16.4.3 病毒的类型 515
16.4.4 宏病毒 516
16.4.5 反病毒方法 517
16.4.6 电子邮件病毒 519
16.5 可信系统 519
16.5.1 特洛伊木马的防范 521
16.6 Windows安全 523
16.6.1 访问控制方案 523
16.6.2 访问令牌 523
16.6.3 安全描述符 524
16.7 小结 526
16.8 推荐读物和网站 527
16.9 关键术语、复习题和习题 528
附录16A 加密 530
A.1 互斥:软件方法 534
附录A 并发主题 534
A.2 竞争条件和信号量 538
A.3 理发店问题 543
A.4 习题 546
附录B 面向对象设计 548
B.1 动机 548
B.2 面向对象的概念 548
B.3 面向对象设计的优点 551
B.4 CORBA 551
B.5 推荐读物和网站 554
附录C 程序设计和操作系统项目 555
C.1 用于教学的操作系统项目 555
C.2 Nachos 555
C.4 程序设计项目 556
C.3 研究项目 556
C.5 阅读/报告作业 557
附录D OSP:一个操作系统项目环境 558
D.1 概述 558
D.2 OSP的创新 559
D.3 和其他操作系统课件的比较 559
附录E BACI:BEN-ARI并发程序设计系统 561
E.1 引言 561
E.2 BACI 561
E.3 BACI程序例子 563
E.4 BACI项目 567
E.5 BACI系统的增强 569
术语表 570
参考文献 577
索引 591