《计算思维之程序设计》PDF下载

  • 购买积分:14 如何计算积分?
  • 作  者:沈军编著
  • 出 版 社:南京:东南大学出版社
  • 出版年份:2018
  • ISBN:9787564179724
  • 页数:420 页
图书介绍:本书以计算思维原理重构程序设计知识体系,并用C++语言进行描述。全书分为“基础篇、方法篇和应用篇”,基础篇主要是给出程序设计两个基本部分——数据组织和数据处理的基本方法;方法篇主要介绍面向功能方法和面向对象方法两种主流程序设计方法,并解析其内在联系;应用篇围绕“C++内置应用、框架式程序设计、应用模式及应用以及通用应用及其思维解析”这一思路展开。本书可以作为普通高校程序设计课程的参考教材,也适合已有一定基础、需要进一步系统化提高思维能力的广大程序设计人员自学。本书可以作为各个层次程序设计课程相关教师的教学指导用书。

第一篇 基础 3

第1章 走进程序设计 3

1.1 程序与程序设计 3

1.1.1 程序 3

1.1.2 程序设计 4

1.2 程序设计四要素 4

1.2.1 方法 4

1.2.2 语言 5

1.2.3 环境 5

1.2.4 应用 6

1.2.5 程序设计四要素的关系 6

1.3 程序设计的思维特征 7

1.4 程序设计的基本学习策略及其C++映射 7

1.5 本章小结 8

第2章 数据组织基础 10

2.1 数据类型 10

2.2 单个数据的组织 12

2.3 堆叠、关联与绑定 13

2.3.1 堆叠 13

2.3.2 关联 15

2.3.3 绑定 16

2.4 数据组织中的计算思维 17

2.5 常用基本数据组织形态 17

2.5.1 线性数据组织 17

2.5.2 层次数据组织 19

2.5.3 网状数据组织 21

2.5.4 C++语言常用基本数据组织方法及其描述 23

2.6 本章小结 28

第3章 数据处理基础 30

3.1 表达式 30

3.2 基本语句 31

3.2.1 基本处理语句 31

3.2.2 流程控制语句 33

3.3 堆叠与嵌套 34

3.4 数据处理中的计算思维 36

3.4.1 表达式嵌套 36

3.4.2 语句堆叠与嵌套 36

3.5 常用基本数据处理方法 36

3.6 本章小结 52

第二篇 方法 57

第4章 程序设计方法概述 57

4.1 方法与模型 57

4.2 程序构造方法的认识视图 57

4.3 程序构造方法建立的基本原理 58

4.4 两种主流的程序设计方法及其思维联系 59

4.4.1 面向功能方法概述 59

4.4.2 面向对象方法概述 60

4.4.3 两者的思维联系 61

4.5 程序构造方法的进一步认识 61

4.5.1 数据组织与数据处理的关系 61

4.5.2 程序构造方法的计算思维特征 63

4.5.3 C++语言对数据组织和数据处理的统一 63

4.6 本章小结 64

第5章 面向功能方法:函数 65

5.1 基本功能模块的构造机制及其描述 65

5.1.1 基本功能模块构造机制的抽象 65

5.1.2 C++语言对基本功能模块构造机制的支持及描述 66

5.2 常用基本数据处理方法的C++语言函数定义及解析 66

5.3 基本功能模块构造机制对数据组织方法应用的具体规则 68

5.3.1 基本功能模块构造机制中数据组织方法的应用规则 68

5.3.2 C++语言对基本功能模块中数据组织方法的拓展 69

5.4 C++语言对基本功能模块表达模型的进一步拓展 71

5.4.1 空返回值 71

5.4.2 空函数与无参函数 71

5.4.3 默认参数与可变参数 72

5.4.4 多重返回 72

5.4.5 系统库函数 73

5.5 本章小结 74

第6章 面向功能方法:函数关系 76

6.1 函数之间的耦合 76

6.1.1 函数之间交互关系的实现机制 76

6.1.2 函数的调用 77

6.1.3 函数的返回 77

6.1.4 C++语言中函数调用与返回的描述 79

6.2 函数的一种特殊耦合关系——递归 80

6.3 C++语言对函数耦合关系的拓展 82

6.3.1 表达式参数与表达式返回 82

6.3.2 函数重载 83

6.3.3 函数模板 85

6.3.4 高阶函数 88

6.4 C++语言中面向功能方法的程序基本结构 88

6.4.1 多文件结构概述 88

6.4.2 编译预处理 89

6.5 深入认识面向功能方法 92

6.5.1 模型化方法的建立 93

6.5.2 存在的弊端 93

6.5.3 多维思维特征 93

6.6 本章小结 94

第7章 面向对象方法:对象 102

7.1 概述 102

7.1.1 数据类型的重要性 102

7.1.2 运用面向功能方法拓展新的数据类型——抽象数据类型(对象) 102

7.1.3 C++语言对抽象数据类型的支持机制及其拓展 104

7.2 数据类型拓展后带来的问题及其处理 107

7.2.1 实例的构造和销毁 107

7.2.2 默认构造函数与复制构造函数 111

7.2.3 初始化参数列表 112

7.2.4 同一种对象多个实例之间的数据共享 115

7.2.5 实例访问与this指针 116

7.2.6 如何实现新类型的基本运算 117

7.2.7 如何解决类型不一致问题 124

7.2.8 如何实现新类型的输入和输出(可流类) 126

7.3 让对象生活在面向功能方法时代 130

7.3.1 基于抽象数据类型的数据组织方法 130

7.3.2 基于抽象数据类型的数据处理方法 135

7.3.3 支持抽象数据类型的面向功能方法的程序构造 140

7.4 深入认识数据类型 142

7.5 本章小结 143

第8章 面向对象方法:对象关系 146

8.1 对象关系概述 146

8.2 对象嵌套关系 147

8.2.1 对象嵌套时的实例构造与析构 147

8.2.2 宿主对象的使用 149

8.3 同族对象之间的关系 152

8.3.1 继承(或普通遗传) 152

8.3.2 多态(或遗传变异) 169

8.3.3 C++语言对继承和多态的拓展 173

8.3.4 对同族关系的进一步认识 176

8.4 抽象数据类型的进一步抽象与拓展 177

8.4.1 类模板 177

8.4.2 类模板特化 177

8.4.3 类模板与继承 179

8.4.4 泛型编程 179

8.5 C++语言中面向对象方法的程序基本结构 179

8.6 深入认识面向对象的方法 180

8.7 本章小结 181

第9章 共享、安全与性能 191

9.1 共享 191

9.1.1 函数内的共享 191

9.1.2 抽象数据类型内的共享 192

9.1.3 单文件程序内的共享 192

9.1.4 多文件程序内的共享 193

9.1.5 共享带来的问题 193

9.2 安全 193

9.2.1 引用 193

9.2.2 const限定 194

9.2.3 异常控制 196

9.2.4 动态类型检查 196

9.3 性能 197

9.3.1 inline函数 197

9.3.2 类的友元 197

9.3.3 类数据成员的mutable限定 198

9.3.4 临时变量 199

9.3.5 初始化参数列表 201

9.4 对共享、安全与性能的综合认识 202

9.5 本章小结 202

第三篇 应用 207

第10章 程序设计应用概述 207

10.1 什么是应用 207

10.2 应用的思维特征及其C++映射 208

10.2.1 应用的思维特征 208

10.2.2 应用思维特征的C++映射 208

10.3 学习应用的基本策略 209

10.4 本章小结 209

第11章 I/O流 211

11.1 什么是I/O流 211

11.2 C++I/O流机制的实现概述 214

11.3 C++标准I/O流 216

11.3.1 标准输入流类型及其使用 217

11.3.2 标准输出流类型及其使用 219

11.3.3 对标准I/O流的深入认识 219

11.4 标准I/O流的状态管理和格式控制 220

11.5 文件I/O流 224

11.5.1 操作系统文件处理的一般原理 224

11.5.2 如何创建文件输入流对象实例 225

11.5.3 如何创建文件输出流对象实例 225

11.5.4 如何关闭文件I/O流 226

11.5.5 如何访问文件 226

11.5.6 文件流应用示例及解析 229

11.6 对I/O流的深入认识 234

11.6.1 I/O流概念的认知层次 234

11.6.2 I/O流概念的通用性 234

11.6.3 I/O流机制的安全性 234

11.6.4 I/O流概念的递归性 235

11.6.5 I/O流的模板化(模板化I/O流) 235

11.6.6 标准I/O流体系的可扩展性 235

11.7 本章小结 235

第12章 字符串 238

12.1 字符串的传统处理方法 238

12.1.1 通过字符数组处理符号串 238

12.1.2 通过字符型指针处理符号串 239

12.1.3 传统处理方法存在的问题 241

12.2 自己构建字符串数据类型String 241

12.3 C++标准库的字符串数据类型string 247

12.4 字符串流 249

12.5 进一步认识字符串 252

12.6 本章小结 254

第13章 异常 255

13.1 什么是异常 255

13.2 如何处理异常 255

13.3 C++异常处理机制 256

13.3.1 异常处理框架及其描述 256

13.3.2 C++异常机制使用的基本规则 259

13.3.3 异常处理时的对象实例析构 261

13.4 深入认识异常 262

13.5 本章小结 262

第14章 标准模板库及其应用 265

14.1 泛型程序设计及其思维本质 265

14.1.1 泛型程序设计 265

14.1.2 泛型程序设计的思维本质 265

14.2 C++标准模板库STL 266

14.2.1 STL的基本原理及其体系结构 266

14.2.2 对类型通用化的处理 267

14.2.3 实例解析 270

14.2.4 STL的基本应用 273

14.2.5 深入认识STL 277

14.3 本章小结 277

第15章 基于框架的程序设计 279

15.1 基于框架的程序设计基本思维 279

15.2 MFC框架的基本原理 280

15.2.1 Windows操作系统定义的基本程序模型 280

15.2.2 MFC对Windows基本程序模型的包装 283

15.2.3 MFC与Visual C++的关系 301

15.3 MFC框架的基本应用 302

15.3.1 MFC框架编程概述 302

15.3.2 MFC框架编程的基本步骤 303

15.3.3 应用示例及解析 303

15.3.4 从Visual C++到Visual Studio 325

15.4 深入认识基于框架的程序设计 325

15.4.1 框架式程序设计方法的必要性 325

15.4.2 MFC框架的高级应用 326

15.5 本章小结 332

第16章 应用模式及其建构 335

16.1 基本应用模式及其建构 335

16.1.1 基本惯用法及其建构 335

16.1.2 数据组织结构中的基本应用模式及其建构 338

16.1.3 数据处理算法中的基本应用模式及其建构 345

16.2 设计模式及其建构 355

16.2.1 MVC模式及其建构 355

16.2.2 工厂方法模式及其建构 357

16.2.3 适配器模式及其建构 361

16.3 模式及其建构应用中的计算思维 363

16.4 本章小结 363

第17章 广谱隐式应用 366

17.1 什么是广谱隐式应用 366

17.2 广谱隐式应用的核心与关键 366

17.3 应用示例 367

17.4 深入认识广谱隐式应用 373

17.5 本章小结 374

第18章 应用之道 376

18.1 应用的进化之道 376

18.2 应用的思维之道 377

18.3 应用之大道 377

18.4 本章小结 377

附录A ASCII字符集 378

附录B C++语言定义的运算符 379

附录C 标准库cstring的函数定义(基于面向功能方法的字符串处理函数) 381

附录D 标准库string类的定义 383

附录E 典型风格MFC程序描述 388

附录F MFC程序去框架特征的回归 396

附录G C++开发环境简介 413

附录H 程序设计之计算思维准则 419

参考文献 420