第1章 C语言概述 1
1.1 C语言的起源 1
1.2 C语言是中级语言 1
1.3 C语言是结构化语言 2
1.4 C语言是面向程序员的语言 3
1.5 编译和解释 4
1.6 C语言程序结构 4
1.6.1 库和链接 6
1.6.2 分别编译 7
1.6.3 编译C语言程序 7
1.6.4 C语言的内存映象 7
1.7 术语 8
习题 8
第2章 数据类型和表达式 9
2.1 数据类型 9
2.2 保留字、标识符 10
2.2.1 标识符 10
2.2.2 保留字 10
2.2.3 选择合适的标识符 11
2.2.4 常量与变量 11
2.3 基本数据类型 12
2.3.1 数据的内部表示 13
2.3.2 字符型 14
2.3.3 整型 16
2.3.4 浮点类型和双精度类型 17
2.3.5 字符串常量 19
2.3.6 符号常量 19
2.4 运算符与表达式 20
2.4.1 表达式 20
2.4.2 算术运算符及算术表达式 20
2.4.3 关系运算符及关系运算表达式 22
2.4.4 逻辑运算符及逻辑表达式 22
2.4.5 赋值表达式 23
2.4.6 逗号表达式 23
2.4.7 表达式的运算顺序 24
2.4.8 条件运算 24
2.4.9 sizeof运算 24
2.4.10 运算符优先级与结合性质 25
2.5 数据类型转换 26
2.5.1 隐式类型转换 27
2.5.2 强制类型转换 27
2.6 位运算 28
2.7 数组和指针 30
2.7.1 数组 30
2.7.2 指针 31
2.7.3 指针和数组的简单用法 33
2.8 简单应用程序举例 36
本章小结 37
习题 38
第3章 结构化程序设计 40
3.1 顺序结构程序设计 40
3.1.1 赋值语句 40
3.1.2 数据输入 42
3.1.3 数据输出 45
3.2 选择结构程序设计 52
3.2.1 条件语句(if) 52
3.2.2 开关选择语句 58
3.2.3 goto语句 61
3.3 循环结构程序设计 62
3.3.1 3种循环结构的流程表示及执行过程 63
3.3.2 循环的嵌套结构 66
3.3.3 循环程序举例 67
3.3.4 循环辅助控制 75
本章小结 78
习题 78
第4章 函数 81
4.1 C语言程序的结构 81
4.2 函数的定义和调用 81
4.2.1 函数的定义 82
4.2.2 函数的调用 83
4.3 变量的存储类别和变量的使用范围 85
4.3.1 变量的存储类别 86
4.3.2 变量的作用范围 88
4.4 函数间的传值 89
4.5 函数的嵌套调用 93
4.6 函数的递归调用 94
4.6.1 递归函数及其执行特点 94
4.6.2 实现递归调用的两种结构 95
4.6.3 递归结构的函数用法举例 95
4.7 函数的应用举例 98
本章小结 101
习题 101
第5章 编译预处理 103
5.1 宏定义 103
5.1.1 不带参数的宏定义 103
5.1.2 带参数的宏定义 105
5.2 文件包含 106
5.3 条件编译 109
本章小结 110
习题 111
第6章 复合数据类型 112
6.1 指针类型 112
6.1.1 指针的声明 112
6.1.2 指针的引用 113
6.1.3 指针的运算 113
6.2 数组类型 115
6.2.1 一维数组的声明 115
6.2.2 一维数组元素的引用与初始化 116
6.2.3 数组作为函数的参数 117
6.2.4 二维数组的声明与使用 119
6.2.5 二维数组元素的引用与初始化 120
6.2.6 指针与数组 121
6.2.7 指针数组与数组指针 122
6.3 字符串 125
6.3.1 字符串常量与变量 126
6.3.2 字符串数组 127
6.3.3 有关字符串操作的系统库函数 129
6.3.4 字符串的用法举例 131
6.4 结构类型 134
6.4.1 结构类型 134
6.4.2 访问结构体成员 136
6.4.3 结构指针和结构数组 137
6.4.4 结构指针作为函数的参数 143
6.4.5 结构体类型及结构指针的应用举例 143
6.5 关于指针的另外几种用法 154
6.5.1 指向函数的指针 154
6.5.2 指针类型的函数 158
6.5.3 指向指针的指针(二级指针) 159
6.6 main()函数的参数 161
6.7 联合、枚举和类型别名 164
6.7.1 联合类型 164
6.7.2 枚举类型 167
6.7.3 类型别名 168
本章小结 169
习题 169
第7章 文件及其操作 174
7.1 C语言文件的概念 174
7.1.1 ANSI C的I/O和UNIX C的I/O 174
7.1.2 流和文件 175
7.1.3 C语言文件 177
7.2 文件系统的基础 177
7.2.1 定义文件结构体类型的指针 178
7.2.2 用于文件操作的函数 179
7.3 建立文件的基本步骤 195
7.4 读取文件的基本步骤 196
7.5 非缓冲文件系统 197
7.5.1 open()函数 198
7.5.2 close()函数 199
7.5.3 creat()函数 199
7.5.4 read()和write()函数 200
7.5.5 unlink()函数 201
7.5.6 lseek()函数 201
7.5.7 缓冲文件系统和非缓冲文件系统的区别 202
本章小结 203
习题 203
第8章 基本应用综合举例 204
8.1 数组元素的查找和排序 204
8.1.1 排序及应用 204
8.1.2 查找 210
8.2 数值积分 213
8.2.1 矩形法 213
8.2.2 梯形法 214
8.2.3 辛普生法 215
8.3 非线性方程的求根 217
8.3.1 牛顿迭代法 217
8.3.2 二分法 219
8.3.3 弦截法 220
8.4 C语言动态数据结构及其用法 220
8.4.1 动态存储分配 221
8.4.2 线性动态数据结构及链表的应用 222
8.4.3 非线性动态数据结构及二叉树的应用 228
8.5 文件的应用 230
8.5.1 用户数据文件的应用 231
8.5.2 用户文本文件的应用 233
习题 240
第9章 C++程序设计基础 241
9.1 从C到C++ 241
9.2 面向对象程序设计 242
9.2.1 面向对象的概念及程序结构 242
9.2.2 面向对象程序设计的实现 243
9.3 C++程序开发过程 244
9.4 C++程序示例 245
9.5 C++对函数功能的增强 246
9.5.1 C++用函数组织程序 246
9.5.2 函数驱动C++程序 246
9.6 C++对数据类型的扩充 249
9.6.1 基本数据类型 249
9.6.2 自定义数据类型 249
9.6.3 从结构到类 249
9.6.4 类与结构的区别 251
9.7 C++运算符的扩充 251
9.7.1 基本运算符 251
9.7.2 运算符重载 252
9.7.3 运算符作为成员函数 254
9.7.4 转换运算符 257
9.7.5 赋值运算符 259
本章小结 262
习题 263
第10章 C++语言基础 264
10.1 C++的类 264
10.2 C++的输入与输出 266
10.3 类与对象 267
10.3.1 类的定义与对象的引用 267
10.3.2 构造函数与析构函数 270
10.3.3 函数重载 275
10.3.4 友元 276
10.4 对象指针 280
10.5 派生类与继承类 286
10.5.1 派生类及其定义 286
10.5.2 单继承的派生类 287
10.5.3 多继承的派生类 295
10.6 虚拟函数与多态性 301
10.6.1 虚拟函数使用方法 301
10.6.2 虚拟函数与重载函数 302
10.6.3 虚拟函数的继承 303
本章小结 304
习题 304
参考文献 308