1 导论 1
1.1 电脑的基本能力 4
1.1-1 手操作型计算器 4
1.1-2 程式储存型电脑 5
1.1-3 作业系统与翻译器 5
1.1-4 分时规划及分离式终端机 7
1.1-5 微电脑 7
1.2 电脑结构 8
1.3 运用於不同电脑使用层面的各种语言 10
1.3-1 程式的发展与类别 13
1.4 程式的处理 14
1.5 作业系统软体:导论 15
1.5-1 CP/M作业系统导论 20
1.5-2 IBM PC DOS的导论 23
1.6 编辑器导论 27
1.6-1 CP/M编辑器 29
1.6-2 IBM PC的DOS编辑器 31
1.7 本章总结 33
2 机器层面的设计:主记忆体及CPU 35
2.1 整数与字符码 35
2.1-1 16进制与8进制 38
2.2 记忆体 39
2.2-1 符号选址 40
2.2-2 Multibyte(多位元组)资料的选址 41
2.3 中央处理器及其运作 43
2.3-1 含三个位址的指令 44
2.3-2 二个位址的指令 45
2.3-3 单位址指令 48
2.3-4 堆叠(零、位址)指令 49
2.3-5 CPU暂存器 51
2.3-6 INTEL 8080的资料暂存器及指令 53
2.3-7 INTEL 8086/88指令及暂存器 55
2.4 指令的形式及顺序 57
2.4-1 INTEL 8080的控制 59
2.4-2 INTEL 8086/88的控制 62
2.5 组合语言 64
2.5-1 组译器的指令形式 64
2.5-2 资料的定义及经由虚拟指令来储存资料 68
2.5-3 组译器定位指令 69
2.5-4 CP/M组译器 71
2.5-5 IBM PC组译器 74
2.6 除错器 77
2.6-1 INTEL 8080的DDT 78
2.6-2 IBM PC之除错器 80
2.7 位址结构 83
2.7-1 索引暂存器 83
2.7-2 基底(base)及分段(segment)暂存器 88
2.7-3 间接选址及直接运算元 89
2.7-4 INTEL 8080的选址结构 91
2.7-5 INTEL 8086/88选址结构 94
2.8 逻辑运算 98
2.8-2 INTEL 8086/88的逻辑运算 100
2.8-1 INTEL 8080的逻辑运算 100
2.9 程式结构的厘定与规划 101
2.9-1 INTEL 8080的编码 103
2.9-2 INTEL 8086/88的编码 104
2.10 本章总结 105
问题 106
3 资料的表示方法 111
3.1 整数与定点数字 111
3.1-1 四舍五入及范围 112
3.1-2 二进位数字的移位 113
3.2 正负号的表示方法 114
3.2-1 2的补数表示法 114
3.2-2 1的补数表示形式 120
3.3 数的转换 121
3.4 浮点表示法 125
3.5 同位位元 127
3.6 电脑中的算术运算 129
3.6-1 INTEL 8080的算术运算 133
3.6-2 INTEL 8086/88的算术运算 137
3.7 本章总结 140
问题 141
4 输入、输出及次储存装置 145
4.1 输入/输出装置 146
4.1-1 线上终端机 146
4.1-2 行及页印表机 147
4.1-3 绘图器及显示装置 147
4.1-4 网路 149
4.1-5 打孔卡 150
4.1-6 打孔纸带 151
4.1-7 文件阅读机及其他I/O装置 152
4.2 大笔资料的储存 153
4.2-1 磁带 153
4.2-2 磁碟档案单元 157
4.2-3 磁带与磁碟的演变 160
4.3 中期的资料储存装置 161
4.3-1 不可搬移的磁碟 161
4.3-2 磁鼓 162
4.3-3 大块储存装置 162
4.5 本章总结 163
4.4 速度与容量方面的比较 163
问题 164
5 副程式 167
5.1 参数及资料的传送 169
5.1-1 INTEL 8080的副程式及参数 174
5.1-2 INTEL 8086/88的副程式及参数 176
5.2 参数连结的架构 178
5.3 副程式的通则 181
5.3-1 堆叠框 183
5.3-2 INTEL 8080及8086/88副程式 185
5.4 递回 186
5.5 可重入(reentrant)程式、单纯程序(pure procedures) 188
5.6 副程式之用於结构 189
问题 190
5.7 本章总结 190
6 作业系统及系统程式 193
6.1 系统命令阶层 193
6.1-1 CP/M的命令阶层 200
6.1-2 IBM DOS的命令阶层 201
6.2 执行支援 203
6.2-1 CP/M为INTEL 8080所做的执行支援 207
6.2-2 IBM PC DOS所提供之执行阶段的支援 216
6.3 两段式组译器 223
6.3-1 CP/M组译器 227
6.3-2 IBM PC之组译器 231
6.4 载入器 235
6.4-1 重新定位载入器 236
6.4-2 链结载入器 238
6.4-3 程式库 241
6.4-4 起始程式之载入 242
6.4-5 CP/M(INTEL 8080)之载入程序 243
6.4-6 链结、IBM PC编辑器 244
6.5 本章总结 246
问题 247
7 条件组合语言及巨集程式 253
7.1 条件组合语言 254
7.2 巨集程式 257
7.2-1 巨集程式中的参数 258
7.2-2 巢状呼叫 263
7.2-4 递回式巨集程式 266
7.2-3 巢状定义 266
7.2-5 巨集程式的重新定义 268
7.3 CP/M DOS的条件组合语言及巨集程式 269
7.4 本章总结 274
问题 275
8 输出、输入的控制及同时处理 279
8.1 CPU直接控制I/O 279
8.1-1 I/O元件之定位 281
8.1-2 I/O缓冲及中断 282
8.1-3 直接记忆存取之I/O方式 284
8.2 中断和陷滞 285
8.2-1 陷滞 286
8.2-2 中断 287
8.2-3 中断之硬体及程序 288
8.2-4 同体程序间之同步 291
8.2-5 8080系统的中断 295
8.3 通道 297
8.3-1 通道电脑 298
8.4 I/O的软体 300
8.4-1 与元件无关之I/O 300
8.4-2 缓冲 302
8.4-3 对错误之处理 305
8.5 本章总结 305
问题 307
9 硬体的层面 311
9.1 电脑设计的概论 311
9.1-1 CPU资料流程 312
9.1-2 记忆体资料流程 316
9.2 控制 317
9.2-1 固线式控制 320
9.2-2 微电脑程式控制 321
9.3 微处理器系统 323
9.3-1 Z80 CPU 325
9.3-2 记忆体 327
9.3-3 I/O 328
9.4 本章总结 333
问题 333
10 多重程式规划与多工处理器 335
10.1 多重程式规划 336
10.1-1 记忆体的定位,重定位以及保护 337
10.2 多工处理器 344
10.3 分时规划 345
10.4 本章总结 346
问题 346
11 组译器 349
11.1 过程Ⅰ:位置计数器 350
11.1-1 基本组译器的程式设计:过程Ⅰ 352
11.1-2 程式规划技巧 356
11.2 过程Ⅱ 364
11.3 虚拟指令及定位指令 365
11.3-1 资料载入虚拟指令 366
11.3-2 影响到位置计数器的定位指令 366
11.3-3 影响到符号表的定位指令 367
11.3-4 其他特殊用途的定位指令 368
11.4 中间语言 369
11.5 重定位、款项以及外部变数 370
11.6 巨集程式 373
11.6-1 扩展的方法 374
11.6-2 另加一前置过程来处理巨集程式的扩展 379
11.7 本章总结 380
问题 381
12 搜寻与排序 383
12.1 顺序搜寻 384
12.1-1 搜寻的预期长度 385
12.2 二进位搜寻技巧 385
12.2-2 二进位与顺序搜寻分法的比较 389
12.2-1 将二进位搜寻方法用於组译器等符号表上 389
12.3 排序 390
12.3-1 顺序排序的方法 391
12.3-2 合并方法 391
12.3-3 数基方法 393
12.3-4 当各记录很长时的内部排序 396
12.4 杂乱定位 398
12.5 炼结技巧 401
12.5-1 顺序搜寻与删除 402
12.5-2 二元树方法 404
12.5-3 堆积排序 406
12.6 本章总结 410
问题 411
索引 413