第1章 汇编语言基础知识 1
1.1 汇编语言简介 1
1.1.1 机器语言与汇编语言 1
1.1.2 为什么要学习汇编语言 2
1.2 计算机中数据的表示 2
1.2.1 不同进位计数制及其相互转换 2
1.2.2 二进制数和十六进制数的运算 5
1.2.3 带符号数的补码表示 5
1.2.4 补码的加法和减法 6
1.2.5 无符号数的表示 7
1.2.6 字符的表示 7
1.2.7 基本逻辑运算 8
1.3 计算机组织 9
1.3.1 计算机系统组成 9
1.3.2 中央处理器(CPU)中的寄存器 10
1.3.3 存储器 13
1.3.4 CPU对存储器的读写操作 15
1.3.5 外部设备和接口 17
1.3.6 32位80x86CPU的工作模式 18
习题 18
第2章 汇编语言程序实例及上机操作 20
2.1 汇编语言的工作环境 20
2.1.1 汇编语言的系统工作文件 20
2.1.2 进入DOS命令行方式 21
2.1.3 常用的DOS命令 21
2.2 汇编语言程序实例 23
2.2.1 单个字符的键盘输入与显示输出 23
2.2.2 显示字符串 24
2.3 程序实例的上机步骤 25
2.3.1 编辑——建立ASM源程序文件 25
2.3.2 汇编——产生OBJ二进制目标文件 25
2.3.3 连接——产生EXE可执行文件 26
2.3.4 LST列表文件 26
2.3.5 程序的运行和调试 28
2.4 几个常用的DOS系统功能调用(INT21H) 30
2.5 DEBUG主要命令 32
习题 35
第3章 操作数的寻址方式 37
3.1 立即寻址方式(immediate addressing) 37
3.2 寄存器寻址方式(register addressing) 38
3.3 直接寻址方式(direct addressing) 38
3.4 寄存器间接寻址方式(register indirect addressing) 39
3.5 寄存器相对寻址方式(register relative addressing) 40
3.6 基址变址寻址方式(based indexed addressing) 41
3.7 相对基址变址寻址方式(relative based indexed addressing) 41
习题 42
第4章 指令系统 44
4.1 数据传送指令 45
4.1.1 通用数据传送指令 45
4.1.2 累加器专用传送指令 47
4.1.3 地址传送指令 49
4.1.4 标志寄存器传送指令 49
4.2 算术运算指令 50
4.2.1 类型扩展指令 50
4.2.2 加法指令 50
4.2.3 减法指令 52
4.2.4 乘法指令 54
4.2.5 除法指令 55
4.2.6 BCD码的十进制调整指令 57
4.2.7 非压缩BCD码的十进制调整指令 58
4.3 逻辑与移位指令 59
4.3.1 逻辑指令 59
4.3.2 移位指令 61
4.4 串操作指令 62
4.4.1 MOVS串传送指令 62
4.4.2 CMPS串比较指令 65
4.4.3 SCAS串扫描指令 66
4.4.4 STOS串存入指令 68
4.4.5 LODS从串取数指令 68
4.5 程序转移指令 69
4.5.1 无条件转移指令与程序的可重新定位 69
4.5.2 条件转移指令 72
4.5.3 循环指令 74
4.5.4 子程序调用 75
4.5.5 中断调用指令 76
4.6 处理器控制指令 77
4.6.1 标志处理指令 77
4.6.2 其他处理机控制指令 77
4.7 80386后继机型的新增指令和寻址方式(*) 78
4.7.1 数据传送指令 78
4.7.2 位操作指令 79
4.7.3 串操作指令 80
4.7.4 算术指令和其他指令 81
4.7.5 条件测试并设置指令 82
4.7.6 增加的寻址方式 82
习题 84
第5章 伪指令与源程序格式 88
5.1 伪指令 88
5.1.1 处理机选择伪指令 88
5.1.2 段定义伪指令 89
5.1.3 程序开始和结束伪指令 91
5.1.4 数据定义与存储器单元分配伪指令 91
5.1.5 类型属性操作符 92
5.1.6 THIS操作符和LABEL伪操作 93
5.1.7 表达式赋值伪指令“EQU”和“=” 94
5.1.8 汇编地址计数器$与定位伪指令 94
5.1.9 基数控制伪指令 95
5.1.10 过程定义伪指令 96
5.2 语句格式 96
5.2.1 名字项和操作项 97
5.2.2 表达式和操作符 97
5.3 EXE文件与COM文件 100
5.3.1 程序段前缀PSP 100
5.3.2 用RET指令结束主程序 101
5.3.3 COM文件 102
习题 103
第6章 分支与循环程序设计 107
6.1 分支程序设计 107
6.1.1 分支程序结构 107
6.1.2 单分支程序 108
6.1.3 复合分支程序 108
6.1.4 多分支程序 110
6.2 循环程序设计 111
6.2.1 循环程序结构 111
6.2.2 计数循环程序 112
6.2.3 条件循环程序 115
6.2.4 条件计数循环程序 118
6.2.5 多重循环程序 120
习题 123
第7章 子程序设计 125
7.1 子程序结构 125
7.1.1 过程定义与过程结构 125
7.1.2 保存和恢复现场寄存器 127
7.2 子程序的参数传递 127
7.2.1 用寄存器传递参数 128
7.2.2 用变量传递参数 131
7.2.3 用地址表传递参数的通用子程序 132
7.2.4 用堆栈传递参数的通用子程序 133
7.2.5 用结构变量传递参数的通用子程序 135
7.3 多模块程序设计 139
7.3.1 多模块之间的参数传递 139
7.3.2 显示十进制数的通用模块 141
7.3.3 C语言程序调用汇编语言子程序 144
7.3.4 段的完整定义 145
7.3.5 连接程序的作用及对程序设计的要求 146
7.3.6 简化的段定义 147
习题 150
第8章 宏汇编及其他高级伪操作 152
8.1 宏汇编 152
8.1.1 宏定义、宏调用和宏展开 152
8.1.2 宏定义的嵌套 154
8.1.3 宏定义中使用宏调用 155
8.1.4 带间隔符的实参 156
8.1.5 连接操作符& 156
8.1.6 宏替换操作符% 157
8.1.7 LOCAL伪操作 157
8.1.8 使用宏库文件 159
8.2 其他高级伪操作 162
8.2.1 PURGE伪操作 162
8.2.2 列表伪操作 162
8.2.3 重复汇编 163
8.2.4 条件汇编 166
习题 168
第9章 输入输出和中断 170
9.1 外部设备与输入/输出 170
9.1.1 I/O端口 170
9.1.2 I/O指令 171
9.1.3 I/O的数据传送控制方式 172
9.2 中断 175
9.2.1 中断的概念 175
9.2.2 中断向量表 177
9.2.3 中断过程 180
9.3 中断处理程序设计 180
9.3.1 中断处理程序的基本功能 180
9.3.2 中断处理程序设计举例 181
习题 183
第10章 输入输出应用 185
10.1 可编程定时器 185
10.1.1 可编程定时器工作原理 185
10.1.2 定时器驱动扬声器发声 187
10.1.3 通用发声程序 188
10.1.4 乐曲程序 191
10.2 键盘调用 193
10.2.1 字符码与扫描码 193
10.2.2 键盘中断调用 194
10.2.3 键盘缓冲区 195
10.3 显示器的文本方式显示 196
10.3.1 显示方式 196
10.3.2 显示存储器与直接写屏 198
10.3.3 BIOS调用 199
10.4 显示器的图形方式显示 203
10.4.1 图形存储器 203
10.4.2 直接视频显示 205
10.4.3 BIOS功能视频显示 206
10.5 磁盘文件存取 208
10.5.1 文件代号方式存取 208
习题 214
上机实验 215
实验1 上机过程及程序调试 215
实验2 算术及位串处理程序 216
实验3 分支程序设计 216
实验4 循环程序设计 217
实验5 子程序设计 217
实验6 模块化程序设计 218
实验7 宏汇编程序设计 218
实验8 中断程序设计 219
实验9 输入输出程序设计 219
附录1 80x86指令系统一览 220
附录2 伪操作与操作符 234
附录3 中断向量地址一览 247
附录4 DOS系统功能调用(INT 21H) 250
附录5 BIOS功能调用 258
附录6 windows 104键键盘扫描码 264
参考文献 266