1.1 C及C++的由来与发展 1
1 绪论 1
1.2 C语言的主要特点 2
1.3 C程序的基本结构 4
1.3.1 简单的C程序分析 4
1.3.2 C程序的基本结构 6
1.3.3 C程序的书写风格 7
1.4 C程序的编辑、编译与运行 8
习题 8
2 C程序设计基础 9
2.1 字符集与词法符号 9
2.1.1 字符集 9
2.1.2 词法符号 9
2.3.1 常量 12
2.2 C的数据类型 12
2.3 常量与变量 12
2.3.2 变量 13
2.4 整数类型 14
2.4.1 整型常数 14
2.4.2 整型变量 14
2.5 实型数据 16
2.5.1 实型常数 16
2.5.2 实型变量 16
2.6 字符型数据 17
2.6.1 字符常量 17
2.6.2 字符变量 17
2.7 运算符与表达式 19
2.7.1 算术运算符与算术表达式 19
2.6.3 字符串常量 19
2.7.2 赋值运算符与赋值表达式 23
2.7.3 逗号运算符与逗号表达式 24
2.7.4 关系运算符与关系表达式 25
2.7.5 逻辑运算符与逻辑表达式 26
2.7.6 条件运算符与条件表达式 28
2.7.7 位运算符 29
2.7.8 求字节数运算符 31
2.7.9 运算符的优先级与结合性 32
2.8 类型转换 34
2.8.1 自动转换 34
2.8.2 强制转换 35
习题 36
3.1 C语句概述 37
3 C程序的控制结构 37
3.2 程序的三种基本结构 38
3.3 算法与程序设计 39
3.3.1 算法的概念 40
3.3.2 算法的特性 40
3.3.3 算法的表示 41
3.3.4 算法的设计 41
3.3.5 算法的分析 42
3.3.6 程序设计方法 43
3.4 顺序结构 44
3.4.1 赋值语句 44
3.4.2 数据输出 44
3.4.3 数据输入 50
3.4.4 程序举例 53
3.5 分支结构 55
3.5.1 if语句 55
3.5.2 switch语句 59
3.5.3 程序举例 61
3.6 循环结构 66
3.6.1 for语句 67
3.6.2 while语句 69
3.6.3 do-while语句 71
3.6.4 循环的嵌套 73
3.6.5 break、continue与goto语句 75
3.6.6 程序举例 78
3.7 编译预处理 81
3.7.1 宏定义 82
3.7.2 文件包含 85
3.7.3 条件编译 86
习题 88
4.1.2 数组的分类 91
4.1.3 数组在内存中的存放 91
4.1 数组概述 91
4.1.1 数组的概念 91
4 数组 91
4.2 一维数组 92
4.2.1 一维数组的定义与引用 92
4.2.2 一维数组的初始化 93
4.2.3 一维数组程序举例 94
4.3 二维数组 96
4.3.1 二维数组的定义与引用 96
4.3.2 二维数组的初始化 97
4.3.3 二维数组程序举例 98
4.4 字符数组 101
4.4.1 字符数组的定义 101
4.4.2 字符数组的初始化 101
4.4.3 字符数组的输入输出 104
4.4.4 字符串处理函数 105
4.4.5 字符数组应用举例 108
习题 110
5 函数与变量的存储类型 112
5.1 函数概述 112
5.1.1 C函数间的调用关系 112
5.1.2 C函数的分类 112
5.1.3 C语言源程序的编译、连接 113
5.2 库函数 113
5.2.1 库函数概述 113
5.2.2 库函数的分类 113
5.2.3 库函数的调用方法 114
5.3 函数的定义 114
5.3.1 函数的定义 114
5.3.2 空函数 115
5.4 函数参数与函数的返回值 116
5.4.1 形式参数与实际参数 116
5.4.2 函数的返回值 118
5.5 函数的调用 120
5.5.1 函数调用的过程 120
5.5.2 函数调用的一般形式 120
5.5.3 函数调用的方式 121
5.5.4 数据复制方式与地址传送方式传递数据 122
5.5.5 对被调用函数的说明 124
5.6 函数的嵌套与递归 126
5.6.1 函数的嵌套调用 126
5.6.2 函数的递归调用 129
5.7 局部变量与全局变量 132
5.7.1 局部变量 132
5.7.2 全局变量 134
5.8 变量的存储类型 135
5.8.1 存储器类型与变量的生存期 135
5.8.2 变量的存储类型 136
5.8.3 变量存储类型小结 140
习题 141
6 结构体、共用体与枚举类型 142
6.1 结构体 142
6.1.1 结构体类型的定义与结构体变量说明 142
6.1.2 结构体变量成员的赋值与引用 145
6.1.3 结构体类型变量的初始化 146
6.1.4 结构体数组 147
6.2 位域 153
6.2.1 位域的定义 153
6.2.2 位域的使用 154
6.3 共用体 156
6.3.1 共用体类型变量的定义与说明 157
6.3.2 共用体变量的赋值与使用 158
6.4 枚举类型 162
6.4.1 枚举类型的定义与枚举变量的说明 162
6.4.2 枚举类型变量的赋值与使用 162
6.5 类型定义 165
习题 166
7 指针 168
7.1 指针的概念 168
7.2 指针变量的定义与引用 169
7.2.1 指针变量的定义 169
7.2.2 指针变量的引用 170
7.3 指针变量作函数的参数 174
7.4.1 指向数组元素的指针变量 175
7.4 指针与数组 175
7.4.2 指向字符串的指针变量 186
7.5 指向函数的指针变量 188
7.5.1 用函数指针变量调用函数 188
7.5.2 指向函数的指针变量作函数参数 190
7.5.3 返回指针值的函数 192
7.6 指针数组 194
7.6.1 指针数组的定义与使用 194
7.6.2 指向指针的指针变量 196
7.6.3 命令行参数 197
7.7 链表 198
7.7.1 动态存储分配 198
7.7.2 链表的基本概念 199
7.7.3 链表的基本操作 201
习题 208
8.1.2 数据的输入输出与文件的概念 209
8.1.1 数据的存储与组织 209
8 文件 209
8.1 C文件概述 209
8.1.3 数据流与C文件的组织结构 210
8.1.4 缓冲文件与非缓冲文件 211
8.1.5 C文件的读写方式 211
8.2 文件类型指针 211
8.2.1 stdio.h简介 211
8.2.2 文件类型指针的定义 212
8.2.3 文件类型指针变量的定义 212
8.3 文件的打开与关闭 212
8.3.1 文件的操作方式 212
8.3.2 文件的打开 213
8.3.3 文件的关闭 214
8.4.2 字符的读写 215
8.4 文件的读写 215
8.4.1 文件的开始与结束 215
8.4.3 块读写 217
8.4.4 格式化读写 220
8.4.5 数据的其他读写方式 221
8.5 文件的定位 222
8.5.1 文件的位置指针 222
8.5.2 rewind函数 222
8.5.3 fseek函数与随机读写 222
8.5.4 ftell()函数 224
8.6 磁盘文件的处理 224
8.6.1 文件的改名与删除 224
8.6.2 目录路径的处理 225
8.7 出错的检测 227
8.8.1 非缓冲文件的访问 228
8.8 非缓冲文件 228
8.8.2 非缓冲文件的读写 229
8.8.3 lseek函数与非缓冲文件的随机读写 230
习题 231
9 C++概述 233
9.1 C++与OOP 233
9.2 简单C++程序的认识 235
9.3 标准输入/输出流 236
9.4 C++中的函数 238
9.4.1 函数原型 238
9.4.2 函数参数 239
9.4.3 函数重载 240
9.4.4 内联函数 241
9.5 引用 242
9.6 new与delete运算符 243
习题 245
10 类及其使用 246
10.1 C++中类的概念 246
10.2 数据成员与成员函数 248
10.2.1 数据成员 248
10.2.2 成员函数 248
10.3 构造函数与析构函数 250
10.3.1 构造函数 250
10.3.2 析构函数 251
10.4 友元函数 253
10.5 运算符重载 254
10.6 类与指针 257
10.7 应用举例 261
习题 263
11.1 派生类 266
11 继承及其使用 266
11.2 继承时的访问控制 267
11.3 构造函数的继承 270
11.4 多重继承 273
11.5 虚函数 275
11.6 抽象基类 277
11.7 虚拟基类 279
11.8 派生类应用举例 280
习题 282
附录1 ASCII码表 284
附录2 C集成环境介绍 285
附录3 C语言常用的库函数 290
附录4 C语言常见错误分析 295
参考文献 306