《C语言从入门到精通 第2版》PDF下载

  • 购买积分:14 如何计算积分?
  • 作  者:明日科技编著
  • 出 版 社:北京:清华大学出版社
  • 出版年份:2012
  • ISBN:9787302287520
  • 页数:402 页
图书介绍:本书从初学者的角度出发,以通俗易懂的语言,丰富多彩的实例,详细介绍了使用C语言进行程序开发应该掌握的各方面知识。全书共分17章,包括C语言概述,算法,数据类型,运算符与表达式,常用的数据输入、输出函数,选择结构程序设计,循环控制,数组,函数,指针,结构体和共用体等。

第1篇 基础知识 3

第1章 C语言概述 3

1.1 C语言的发展史 4

1.1.1 程序语言简述 4

1.1.2 C语言的历史 4

1.2 C语言的特点 5

1.3 一个简单的C程序 6

1.4 一个完整的C程序 8

1.5 C语言程序的格式 12

1.6 开发环境 13

1.6.1 Turbo C 2.0 13

1.6.2 Visual C++++6.0 17

1.7 小结 22

第2章 算法 23

2.1 算法的基本概念 24

2.1.1 算法的特性 24

2.1.2 算法的优劣 25

2.2 算法的描述 25

2.2.1 自然语言 25

2.2.2 流程图 26

2.2.3 N-S流程图 29

2.3 小结 32

第3章 数据类型 33

3.1 编程规范 34

3.2 关键字 35

3.3 标识符 35

3.4 数据类型 36

3.5 常量 37

3.5.1 整型常量 38

3.5.2 实型常量 40

3.5.3 字符型常量 41

3.5.4 转义字符 43

3.5.5 符号常量 44

3.6 变量 45

3.6.1 整型变量 45

3.6.2 实型变量 47

3.6.3 字符型变量 50

3.7 变量的存储类别 51

3.7.1 动态存储与静态存储 51

3.7.2 auto变量 52

3.7.3 static变量 52

3.7.4 register变量 53

3.7.5 extern变量 54

3.8 混合运算 55

3.9 小结 56

3.10 实践与练习 56

第4章 运算符与表达式 57

4.1 表达式 58

4.2 赋值运算符与赋值表达式 60

4.2.1 变量赋初值 60

4.2.2 自动类型转换 62

4.2.3 强制类型转换 62

4.3 算术运算符与算术表达式 63

4.3.1 算术运算符 63

4.3.2 算术表达式 64

4.3.3 优先级与结合性 65

4.3.4 自增/自减运算符 67

4.4 关系运算符与关系表达式 69

4.4.1 关系运算符 69

4.4.2 关系表达式 69

4.4.3 优先级与结合性 70

4.5 逻辑运算符与逻辑表达式 71

4.5.1 逻辑运算符 72

4.5.2 逻辑表达式 72

4.5.3 优先级与结合性 72

4.6 位逻辑运算符与位逻辑表达式 73

4.6.1 位逻辑运算符 74

4.6.2 位逻辑表达式 74

4.7 逗号运算符与逗号表达式 74

4.8 复合赋值运算符 76

4.9 小结 77

4.10 实践与练习 77

第5章 常用的数据输入/输出函数 79

5.1 语句 80

5.2 字符数据输入/输出 80

5.2.1 字符数据输出 80

5.2.2 字符数据输入 81

5.3 字符串输入/输出 83

5.3.1 字符串输出函数 83

5.3.2 字符串输入函数 85

5.4 格式输出函数 85

5.5 格式输入函数 88

5.6 顺序程序设计应用 92

5.7 小结 93

5.8 实践与练习 94

第6章 选择结构程序设计 95

6.1 if语句 96

6.2 if语句的基本形式 96

6.2.1 if语句形式 96

6.2.2 if...else语句形式 99

6.2.3 else if语句形式 103

6.3 if的嵌套形式 106

6.4 条件运算符 109

6.5 switch语句 110

6.5.1 switch语句的基本形式 111

6.5.2 多路开关模式的switch语句 114

6.6 if...else语句和switch语句的区别 116

6.7 选择结构程序应用 118

6.8 小结 120

6.9 实践与练习 120

第7章 循环控制 121

7.1 循环语句 122

7.2 while语句 122

7.3 do-while语句 125

7.4 for语句 127

7.4.1 for语句使用 127

7.4.2 for循环的变体 130

7.4.3 for语句中的逗号应用 132

7.5 3种循环语句的比较 133

7.6 循环嵌套 134

7.6.1 循环嵌套的结构 134

7.6.2 循环嵌套实例 135

7.7 转移语句 137

7.7.1 goto语句 137

7.7.2 break语句 139

7.7.3 continue语句 140

7.8 小结 141

7.9 实践与练习 141

第2篇 核心技术 145

第8章 数组 145

8.1 一维数组 146

8.1.1 一维数组的定义和引用 146

8.1.2 一维数组初始化 148

8.1.3 一维数组应用 150

8.2 二维数组 151

8.2.1 二维数组的定义和引用 151

8.2.2 二维数组初始化 152

8.2.3 二维数组应用 155

8.3 字符数组 156

8.3.1 字符数组的定义和引用 157

8.3.2 字符数组初始化 157

8.3.3 字符数组的结束标志 159

8.3.4 字符数组的输入和输出 160

8.3.5 字符数组应用 161

8.4 多维数组 162

8.5 数组的排序算法 163

8.5.1 选择法排序 163

8.5.2 冒泡法排序 165

8.5.3 交换法排序 167

8.5.4 插入法排序 169

8.5.5 折半法排序 171

8.5.6 排序算法的比较 174

8.6 字符串处理函数 174

8.6.1 字符串复制 174

8.6.2 字符串连接 176

8.6.3 字符串比较 177

8.6.4 字符串大小写转换 179

8.6.5 获得字符串长度 180

8.7 数组应用 181

8.7.1 反转输出字符串 181

8.7.2 输出系统日期和时间 183

8.7.3 字符串的加密和解密 184

8.8 小结 186

8.9 实践与练习 186

第9章 函数 187

9.1 函数概述 188

9.2 函数的定义 190

9.2.1 函数定义的形式 191

9.2.2 定义与声明 192

9.3 返回语句 194

9.3.1 从函数返回 194

9.3.2 返回值 195

9.4 函数参数 197

9.4.1 形式参数与实际参数 197

9.4.2 数组作函数参数 199

9.4.3 main函数的参数 205

9.5 函数的调用 206

9.5.1 函数的调用方式 206

9.5.2 嵌套调用 209

9.5.3 递归调用 211

9.6 内部函数和外部函数 214

9.6.1 内部函数 214

9.6.2 外部函数 215

9.7 局部变量和全局变量 216

9.7.1 局部变量 217

9.7.2 全局变量 220

9.8 函数应用 221

9.9 小结 227

9.10 实践与练习 228

第10章 指针 229

10.1 指针相关概念 230

10.1.1 地址与指针 230

10.1.2 变量与指针 231

10.1.3 指针变量 231

10.1.4 指针自加自减运算 235

10.2 数组与指针 237

10.2.1 一维数组与指针 237

10.2.2 二维数组与指针 241

10.2.3 字符串与指针 244

10.2.4 字符串数组 246

10.3 指向指针的指针 247

10.4 指针变量作函数参数 250

10.5 返回指针值的函数 258

10.6 指针数组作main函数的参数 260

10.7 小结 262

10.8 实践与练习 262

第3篇 高级应用 265

第11章 结构体和共用体 265

11.1 结构体 266

11.1.1 结构体类型的概念 266

11.1.2 结构体变量的定义 267

11.1.3 结构体变量的引用 269

11.1.4 结构体类型的初始化 271

11.2 结构体数组 273

11.2.1 定义结构体数组 273

11.2.2 初始化结构体数组 275

11.3 结构体指针 277

11.3.1 指向结构体变量的指针 277

11.3.2 指向结构体数组的指针 280

11.3.3 结构体作为函数参数 282

11.4 包含结构的结构 284

11.5 链表 286

11.5.1 链表概述 286

11.5.2 创建动态链表 287

11.5.3 输出链表 290

11.6 链表相关操作 292

11.6.1 链表的插入操作 292

11.6.2 链表的删除操作 294

11.7 共用体 298

11.7.1 共用体的概念 298

11.7.2 共用体变量的引用 299

11.7.3 共用体变量的初始化 300

11.7.4 共用体类型的数据特点 301

11.8 枚举类型 301

11.9 小结 302

11.10 实践与练习 303

第12章 位运算 305

12.1 位与字节 306

12.2 位运算操作符 306

12.2.1 “与”运算符 306

12.2.2 “或”运算符 308

12.2.3 “取反”运算符 309

12.2.4 “异或”运算符 310

12.2.5 “左移”运算符 312

12.2.6 “右移”运算符 313

12.3 循环移位 315

12.4 位段 317

12.4.1 位段的概念与定义 317

12.4.2 位段相关说明 319

12.5 小结 320

12.6 实践与练习 320

第13章 预处理 321

13.1 宏定义 322

13.1.1 不带参数的宏定义 322

13.1.2 带参数的宏定义 323

13.2 #include指令 325

13.3 条件编译 327

13.3.1 #if命令 327

13.3.2 #ifdef及#ifndef命令 329

13.3.3 #undef命令 331

13.3.4 #line命令 331

13.3.5 #pragma命令 332

13.4 小结 333

13.5 实践与练习 333

第14章 文件 335

14.1 文件概述 336

14.2 文件基本操作 336

14.2.1 文件指针 336

14.2.2 文件的打开 337

14.2.3 文件的关闭 338

14.3 文件的读写 338

14.3.1 fputc函数 338

14.3.2 fgetc函数 339

14.3.3 fputs函数 340

14.3.4 fgets函数 341

14.3.5 fprintf函数 342

14.3.6 fscanf函数 343

14.3.7 fread和fwrite函数 344

14.4 文件的定位 346

14.4.1 fseek函数 346

14.4.2 rewind函数 348

14.4.3 ftell函数 349

14.5 小结 352

14.6 实践与练习 352

第15章 存储管理 353

15.1 内存组织方式 354

15.1.1 内存的组织方式 354

15.1.2 堆与栈 354

15.2 动态管理 356

15.2.1 malloc函数 356

15.2.2 calloc函数 357

15.2.3 realloc函数 358

15.2.4 free函数 359

15.3 内存丢失 360

15.4 小结 361

15.5 实践与练习 361

第16章 网络套接字编程 363

16.1 计算机网络基础 364

16.1.1 IP地址 364

16.1.2 OSI七层参考模型 364

16.1.3 地址解析 365

16.1.4 域名系统 366

16.1.5 TCP/IP协议 366

16.1.6 端口 368

16.1.7 套接字的引入 368

16.1.8 网络字节顺序 369

16.2 套接字概述 369

16.2.1 套接字概述 369

16.2.2 TCP的套接字的socket编程 369

16.2.3 UDP的套接字的socket编程 370

16.3 套接字函数 371

16.3.1 套接字函数介绍 371

16.3.2 基于TCP的网络聊天程序 376

16.4 小结 382

16.5 实践与练习 382

第4篇 项目实战 385

第17章 学生成绩管理系统 385

17.1 需求分析 386

17.2 系统设计 386

17.3 功能设计 387

17.3.1 功能选择界面 387

17.3.2 录入学生成绩信息 388

17.3.3 查询学生成绩信息 391

17.3.4 删除学生成绩信息 392

17.3.5 修改学生成绩信息 393

17.3.6 插入学生成绩信息 395

17.3.7 统计学生人数 397

17.4 小结 397

附录A ASCII表 399