第1章 单片机基础知识 1
1.1 单片机的发展概况 1
1.1.1 4位单片机 1
1.1.2 8位单片机 1
1.1.3 16位单片机 1
1.1.4 32位单片机 2
1.2 单片机发展的技术特点 2
1.2.1 单片机寿命长 2
1.2.2 8位、32位单片机共同发展 2
1.2.3 处理速度越来越快 2
1.2.4 低电压与低功耗 2
1.2.5 低噪声与高可靠性技术 2
1.2.6 ISP及IAP技术 2
1.3 单片机的应用 3
1.3.1 工业过程控制 3
1.3.2 智能仪表 3
1.3.3 机电一体化产品 3
1.3.4 计算机网络与通信 3
1.3.5 家用电器 3
1.3.6 数据采集系统的现场采集单元 3
1.3.7 分布控制系统的前端控制器 4
1.3.8 终端及外部设备控制 4
1.4 单片机选型 4
1.4.1 芯片的可靠性及温度等级 4
1.4.2 片内ROM供应状态 4
1.4.3 半导体工艺状态 4
1.5 单片机应用系统的开发过程 5
1.5.1 确定方案,选择芯片 5
1.5.2 硬件电路设计、组装与调试 5
1.5.3 应用软件的调试与仿真 5
1.5.4 应用软件的固化 5
1.5.5 应用系统脱机运行 5
1.6 单片机中的数 6
1.6.1 十进制数 6
1.6.2 二进制数 6
1.6.3 十六进制数 6
1.6.4 二-十进制数(BCD码) 6
1.6.5 数制转换 7
1.6.6 数的表示 7
1.7 单片机的硬件基础 11
1.7.1 布尔代数 11
1.7.2 基本逻辑器件 12
1.7.3 触发器 16
1.7.4 半导体存储器 18
第2章 MCS-51单片机结构 19
2.1 单片机的结构 19
2.1.1 典型单片机的结构 19
2.1.2 MCS-51单片机 19
2.2 单片机的引脚功能 21
2.2.1 MCS-51单片机的硬件结构 21
2.2.2 MCS-51单片机的硬件结构 22
2.2.3 MCS-51系列单片机的存储器组织结构 26
2.2.4 MCS-51系列单片机的输入/输出接口 33
2.2.5 MCS-51系列单片机的时钟电路与CPU时序 36
2.2.6 MCS-51系列单片机的工作方式 37
第3章 MCS-51单片机指令系统 42
3.1 程序设计语言简介 42
3.2 指令格式和寻址方式 42
3.2.1 指令格式 42
3.2.2 寻址方式 43
3.2.3 寻址空间及符号注释 44
3.3 指令系统 45
3.3.1 数据传送指令组 46
3.3.2 算术运算指令组 50
3.3.3 逻辑运算指令组 53
3.3.4 控制转移指令组 55
3.3.5 位操作指令组 58
第4章 C51语言程序设计基础 62
4.1 C语言和MCS-51单片机 62
4.1.1 计算机程序设计语言 62
4.1.2 单片机C语言与汇编语言的对比 64
4.1.3 C51与标准C语言的比较 67
4.2 C51语言的数据类型和存储模式 68
4.2.1 数据类型 68
4.2.2 存储类型及存储区 68
4.2.3 存储模式 70
4.3 C51语言对51单片机内部资源的控制 71
4.3.1 特殊功能寄存器(SFR) 71
4.3.2 绝对地址的访问 73
4.3.3 位变量的C51语言定义 74
4.4 C51语言的基本运算与控制语句 74
4.4.1 C51基本运算 74
4.4.2 C51分支结构控制语句 76
4.4.3 C51循环结构控制语句 76
4.5 C51语言的构造数据类型 79
4.5.1 C51的数组 79
4.5.2 C51的指针 79
4.6 C51语言的函数 80
4.6.1 函数声明 80
4.6.2 中断函数 80
4.6.3 库函数 80
4.7 C51语言程序设计的其他问题 81
4.7.1 使用C51的一些技巧 81
4.7.2 C51使用规范 83
4.8 C51编程举例 84
第5章 并行I/O口 86
5.1 P0口 86
5.2 P1口 87
5.3 P2口 87
5.4 P3口 88
5.5 应用举例 89
第6章 MCS-51的中断系统 91
6.1 中断的概念 91
6.2 MCS-51中断系统的结构 91
6.3 中断请求源 92
6.4 中断控制 93
6.4.1 中断允许寄存器IE 93
6.4.2 中断优先级寄存器IP 94
6.5 中断响应 96
6.6 外部中断的响应时间 97
6.7 外部中断的触发方式选择 97
6.7.1 电平触发方式 97
6.7.2 跳沿触发方式 98
6.8 中断请求的撤消 98
6.8.1 定时器/计数器中断请求的撤消 98
6.8.2 外部中断请求的撤消 98
6.8.3 串行口中断请求的撤消 98
6.9 中断服务程序的设计 99
6.9.1 中断服务程序设计的任务 99
6.9.2 采用中断时的主程序结构 99
6.9.3 中断服务程序的流程 100
6.10 多外部中断源系统设计 101
6.10.1 定时器/计数器作为外部中断源的使用方法 101
6.10.2 中断和查询结合的方法 102
6.10.3 用优先权编码器扩展外部中断源 103
6.11 中断应用程序 106
第7章 定时/计数器 111
7.1 定时/计数器的结构与工作原理 111
7.1.1 硬件结构 111
7.1.2 工作原理 111
7.2 定时/计数器的工作方式 114
7.2.1 方式0 114
7.2.2 方式1 114
7.2.3 方式2 115
7.2.4 方式3 115
7.3 52单片机的定时/计数器2介绍 116
7.3.1 定时/计数器2控制寄存器T2CON 116
7.3.2 定时/计数器2的3种工作模式 117
7.4 定时/计数器的初始化 121
7.4.1 初值的计算 121
7.4.2 中断服务程序的写法 122
7.5 定时器中断应用实例 122
第8章 串行接口 127
8.1 串行通信的一般概念 127
8.1.1 两种基本的通信方式 127
8.1.2 串行通信的传输方向 128
8.1.3 通用异步接收发送器UART 129
8.2 8051单片机的串行口 129
8.2.1 控制寄存器 129
8.2.2 串行通信工作方式 131
8.3 串行接口通信举例 137
第9章 RAM/ROM扩展系统 141
9.1 概述 141
9.1.1 系统扩展概述 141
9.1.2 系统总线 141
9.1.3 构造系统总线 142
9.2 最小系统与程序存储器的扩展 143
9.2.1 程序存储器 143
9.2.2 最小系统 143
9.2.3 用EPROM的程序存储器扩展 145
9.2.4 用EEROM的程序存储器扩展 150
9.3 数据存储器扩展 152
9.3.1 用静态RAM的数据存储器扩展 152
9.3.2 用EEPROM的数据存储器扩展 155
9.3.3 用动态RAM的数据存储器扩展 155
第10章 I/O扩展系统及应用设计 156
10.1 I/O地址译码技术 157
10.1.1 线选法 157
10.1.2 全地址译码法 158
10.2 简单I/O口扩展 159
10.3 8255A可编程并行I/O口扩展 160
10.3.1 8255A的内部结构 160
10.3.2 8255A的工作方式及其选择 161
10.3.3 8255A的控制字及初始化 162
10.3.4 8031单片机与8255A的接口 163
10.4 8155可编程并行I/O口扩展 164
10.4.1 8155芯片逻辑结构和引脚 164
10.4.2 8155的命令/状态寄存器 166
10.4.3 8155的工作方式 166
10.4.4 RAM单元及I/O口编址 167
10.4.5 8155与MCS-51单片机的连接 167
10.4.6 8155的定时/计数器 167
10.4.7 8155定时器和MCS-51定时器的比较 168
10.4.8 8155应用举例 169
10.5 通过串行口扩展 169
10.6 单片机系统扩展 171
10.7 单片机的接口应用 172
附录 MCS-51指令系统 176
参考文献 184