《C++面向对象程序设计》PDF下载

  • 购买积分:20 如何计算积分?
  • 作  者:
  • 出 版 社:
  • 出版年份:2222
  • ISBN:
  • 页数:0 页
图书介绍:

第1章C++基础 1

1.1 C++概述 2

1.1.1程序 2

1.1.2预处理指令 3

1.1.3输入与输出 4

1.1.4 C++编程思想 6

1.1.5基于对象的程序设计 6

1.1.6面向对象的程序设计 7

1.2控制语句 9

1.2.1分支 9

1.2.2循环 12

1.2.3跳转 14

1.3数据类型 15

1.3.1基本数据类型 15

1.3.2文字量 17

1.3.3枚举 19

1.3.4结构体 20

1.3.5共用体 22

1.4指针和数组 23

1.4.1内存开辟 23

1.4.2 void指针 25

1.4.3空指针 26

1.4.4多级指针 26

1.4.5指针数组 28

1.4.6数组指针 28

1.5函数 29

1.5.1传值与传引用 29

1.5.2传指针与传数组 30

1.5.3默认和可变参数 31

1.5.4返回值 33

1.5.5函数和指针 33

1.6思考与练习 35

第2章 认识类 36

2.1类的来源 37

2.2类有哪些成员 38

2.3类可以出现的位置 42

2.4类的极限形式 45

2.5类和结构体的区别 53

2.6类型的演进 54

2.7类的路线图 54

2.8思考与练习 57

第3章 认识类的思想 58

3.1类的封装性 58

3.2类的继承性 61

3.3类的多态性 64

3.3.1编译时多态性 64

3.3.2运行时多态性 67

3.4思考与练习 68

第4章 对象 69

4.1构造函数 70

4.1.1重载构造函数 75

4.1.2默认构造函数 75

4.1.3复制构造函数 78

4.1.4转化构造函数 80

4.1.5显式构造函数 82

4.1.6区分构造形式 83

4.2析构函数 85

4.3静态成员 88

4.3.1静态成员函数 88

4.3.2静态数据成员 92

4.4常量成员 100

4.4.1常量成员函数 100

4.4.2常量数据成员 100

4.4.3常量和非常量的区别 101

4.5静态与常量成员 102

4.6内联函数和友元函数 103

4.6.1内联函数 103

4.6.2友元函数与友元类 106

4.7对象数组 109

4.8创建特殊对象 111

4.9思考与练习 113

第5章 运算符重载 114

5.1可重载的运算符 115

5.2重载的原则 115

5.3定义新运算符 116

5.4运算符的原有语义 117

5.5对象或全局函数 120

5.6运算符的参数 123

5.7独立和复合运算符 126

5.8赋值运算符不参与继承 126

5.9重载运算符的限定 128

5.10改变运算符的可见性 130

5.11相等 132

5.12赋值 134

5.13下标 136

5.14函数调用 138

5.15类型转化 141

5.16增量和减量 142

5.17分配和释放 144

5.18思考与练习 146

第6章 完整的String类 147

6.1引言 148

6.2确定目标 148

6.3设计接口 148

6.4定义接口 149

6.5字符串的创建 151

6.6字符串的销毁 155

6.7字符串与字符数组 155

6.8安全数据 156

6.9赋值、下标和其他 157

6.10算法 158

6.11提取 161

6.12大小和容量 164

6.13比较 164

6.14输入和输出 166

6.15 异常处理 166

6.16简单的应用 167

6.17思考与练习 169

第7章 继承 170

7.1可能的继承方式 171

7.2看待各种继承 173

7.3类和结构体彼此继承 173

7.4认识虚拟继承 175

7.5使用空类型 177

7.6“共同”的使用 179

7.7继承中的构造和析构 181

7.7.1构造函数的调用顺序 181

7.7.2析构函数的调用顺序 185

7.7.3虚拟继承对象的构造 185

7.8思考与练习 186

第8章 内存布局 187

8.1要解决的问题 188

8.2内存有哪些成员 188

8.3各种内存布局 190

8.3.1独立类型 190

8.3.2单继承 192

8.3.3多继承 193

8.3.4有共同基类的继承 195

8.3.5虚拟继承 197

8.3.6虚函数表指针的存储 200

8.4基类的连续性 202

8.5空类的大小 203

8.6内存的膨胀 203

8.7思考与练习 206

第9章 类型转化 208

9.1对象类型向上转化 209

9.1.1单继承与多继承 209

9.1.2有共同基类的继承 210

9.2对象类型向下转化 211

9.2.1单继承 211

9.2.2多继承 212

9.2.3有共同基类的继承 214

9.3指针类型转化 215

9.4指针类型向上转化 216

9.4.1单继承与多继承 216

9.4.2有共同基类的继承 217

9.5指针类型向下转化 218

9.5.1单继承 218

9.5.2多继承 220

9.5.3有共同基类的继承 221

9.6思考与练习 222

第10章 虚拟机制 224

10.1虚函数的声明 225

10.2虚函数的调用 225

10.3抽象类 227

10.3.1抽象类的数据成员 228

10.3.2抽象类的局部派生 229

10.3.3抽象类作为派生类 229

10.4虚析构函数 230

10.5虚函数与虚拟继承 231

10.6虚函数表指针与类型 232

10.7虚函数表项未必相同 232

10.8思考与练习 233

第11章 完整的MiniDataSet类层次结构 235

11.1引言 236

11.2确定目标 236

11.3继承与组合 238

11.4继承类型和数据封装 240

11.5层次结构图 242

11.6定义接口 243

11.7实现接口 249

11.7.1 BaseData接口 249

11.7.2 KeyData接口 249

11.7.3 ValueData接口 250

11.7.4 DicEle接口 251

11.7.5 Dictionary接口 253

11.7.6 NamedDic接口 256

11.7.7 NamedDieSet接口 256

11.7.8 MiniHeader接口 260

11.7.9 MiniTable接口 261

11.8包容性扩展 262

11.9简单的应用 263

11.10思考与练习 266

第12章 综合设计与实现 267

12.1逐步求精类型的设计 268

12.1.1设计需求 268

12.1.2基本表示 268

12.1.3存储结构化 271

12.1.4改善内部表示 273

12.1.5拓展类型的能力 282

12.1.6设计总结 285

12.2受限制类型的设计 285

12.2.1设计需求 286

12.2.2限制函数的返回 286

12.2.3限制函数的参数 287

12.2.4设计总结 289

12.3扩展容器类型的设计 290

12.3.1设计需求 290

12.3.2一对多的映射 290

12.3.3多对多的映射 291

12.3.4设计总结 293

12.4函数组类型的设计 293

12.4.1设计需求 293

12.4.2构造式设计 293

12.4.3运算符式设计 298

12.4.4设计总结 300

12.5跳跃数组类型的设计 300

12.5.1设计需求 300

12.5.2元素类型的设计 301

12.5.3包含类型的实现 305

12.5.4扩展包含类型的接口 307

12.5.5增强包含类型的存储 309

12.5.6设计总结 312

12.6可替换类型的设计 312

12.6.1设计需求 312

12.6.2替换分隔式数组 313

12.6.3替换仅含数据的结构体 316

12.6.4替换类对象数组 318

12.6.5替换函数指针数组 319

12.6.6设计总结 321

12.7统一输入输出类型的设计 321

12.7.1设计需求 321

12.7.2输出的原子动作 321

12.7.3统一的文件输出 324

12.7.4统一的网络输出 325

12.7.5统一的数据输出 327

12.7.6设计总结 329

12.8思考与练习 329

附录 常用英文术语 330

参考文献 331