- 电子工业出版社
- 9787121306631
- 1-1
- 58896
- 47182678-4
- 平塑
- 16开
- 2017-02
- 473
- 256
- 工学
- 软件工程
- TP312C
- 大学计算机公共课程
- 本科 研究生(硕士、EMBA、MBA、MPA、博士)
内容简介
本书可作为第二门程序设计课程的教材,最好应在学过C语言之后使用。本书内容包括过程化设计和面向对象两部分构成,但对过程化设计只以很少篇幅做提要式介绍。全书共分10章。第1章介绍C++语言的预备知识,并用简单示例比较了过程化程序设计与面向对象程序设计在思考问题上的差异,介绍面向对象程序设计的主要特点,基本的面向对象问题分析和程序设计方法。第2章介绍C++语言的过程化语法,并对C++语言中的基本对象作了渗透。第3、4章介绍C++语言的封装特性,第5、6章分别介绍继承和多态性。第7、8章分别讨论运算符重载和流技术。第9章简要说明了建立在类模板基础上的泛型编程技术。第10章介绍了C++的异常处理机制。本书的每章开始以精炼的语言扼要说明其主要内容,难点被适当地分解在各章里。部分重点章节安排了若干有实际背景的设计案例。每章最后配备了若干思考题和相当数量的习题。思考题有助于理解语言的语法现象,值得认真对照教材去分析,或者构造适当的例子去实验,而通过完成这些习题,有助于对知识点的透彻掌握。为了帮助学习者顺利进行编程实践,书后以附录形式对C++Builder 6.0、DEV C++和Visual C++ 6.0这几种环境的编程甚至程序调试方法都给出了适度介绍。
目录
目 录 第1章 C 语言与面向对象程序设计概述 11.1 C 语言概述 11.1.1 标准C 语言的产生与发展 11.1.2 编写简单的C 语言程序 21.2 由过程化到面向对象程序设计 41.2.1 过程化程序设计 41.2.2 面向对象的程序设计 61.3 面向对象程序的主要特征 71.3.1 抽象与封装(encapsulation) 81.3.2 由继承(inheritance)实现重用 91.3.3 由多态(polymorphism)反映 变革 101.4 面向对象的问题分析 111.4.1 确定类 111.4.2 确定类的属性 111.4.3 确定类的方法 121.4.4 确定对象模式 12思考与练习1 13实验1 13第2章 C 语言基础 142.1 标识符与关键字 142.1.1 标识符 142.1.2 关键字 142.2 数据与数据类型 152.2.1 基本数据类型 152.2.3 字面值 152.2.4 符号常量 162.2.5 变量 182.3 基本运算 182.3.1 运算符和表达式 182.3.2 数据类型转换与造型 202.4 语句与流程控制 212.4.1 简单语句与复合语句 212.4.2 分支语句 222.4.3 循环语句 232.4.4 流程转向语句 242.4.5 数据输入与输出 252.5 指针、数组与引用 262.5.1 指针 262.5.2 数组 282.5.3 引用 302.6 函数 312.6.1 函数的定义与声明 312.6.2 函数调用与参数匹配 322.6.3 函数返回值与函数调用表达式 352.6.4 形式参数的默认值 372.6.5 内联函数 372.6.6 函数重载 382.6.7 函数模板 392.7 new、delete与动态对象 422.7.1 动态生成和销毁一个对象 422.7.2 动态生成和销毁对象数组 432.8 名字空间 432.8.1 名字冲突及对策 432.8.2 定义和使用名字空间 442.9 预处理指令 452.9.1 宏定义 452.9.2 条件编译 462.9.3 文件包含 46思考与练习2 47实验2 50第3章 类、对象与封装 513.1 类 513.1.1 类的含义与表述 513.1.2 类定义的语法规则 523.2 对象 553.2.1 对象定义 553.2.2 成员访问 563.2.3 对象存储 583.3 类的方法 593.3.1 为类提供必要的方法 593.3.2 inline方法 613.3.3 const方法 613.3.4 隐含的this指针 623.3.5 方法重载与缺省参数 633.3.6 类的模板函数方法 643.4 构造与析构 643.4.1 初始化的难题 643.4.2 构造函数与对象初始化 653.4.3 无名对象 673.4.4 对象数组与动态对象 683.4.5 初始化列表与特殊成员的 初始化 693.4.6 共用体类与位域类 713.4.7 析构函数与对象拆除 723.5 拷贝构造与对象拆除 733.5.1 拷贝构建新对象 733.5.2 改变缺省的拷贝行为 743.5.3 拷贝构造器的实现 753.5.4 用自己定义的析构器拆除对象 763.6 字符串类string 763.6.1 string类的属性与对象构造 763.6.2 string类支持的主要运算 763.6.3 string类的主要方法 773.7 案例一:设计一个栈类 783.8 案例二:公司员工类的设计(一) 80思考与练习3 83实验3 85第4章 类的静态成员、友元与指针访问 874.1 静态成员 874.1.1 静态属性 874.1.2 静态方法 904.2 友元 914.2.1 友元函数 914.2.2 类方法作为友元 924.2.3 友元类 934.3 指向类成员的指针 944.3.1 利用普通指针访问属性 944.3.2 指向非静态方法的指针 954.4 案例三:账户类的设计 96思考与练习4 98实验4 100第5章 继承与重用 1015.1 继承的概念与表示 1015.1.1 继承与派生 1015.1.2 继承关系的描述 1025.2 继承的实现 1035.2.1 继承的语法形式 1035.2.2 访问父类的成员 1045.3 类之间的关系与类的构造 1075.3.1 继承与聚集 1085.3.2 子类的构造 1095.3.3 派生类的析构 1105.4 复杂对象的构造与析构 1115.4.1 责任重大的构造器 1115.4.2 类成员的构造与析构次序 1125.5 继承的工作方式 1135.5.1 派生类是一种(个)基类 1135.5.2 利用指针和引用的访问 1145.5.3 非public方式派生 1145.6 案例四:公司员工类的设计(二) 1155.6.1 雇员类的定义 1155.6.2 工人类的定义 1165.6.3 经理类的定义 117思考与练习5 118实验5 121第6章 虚函数与多态性 1226.1 多态性及其语法规则 1226.1.1 多态性与联编方式 1226.1.2 用虚函数实现动态绑定 1236.2 共同基类下的对象访问 1246.2.1 概念中的共性 1246.2.2 公共基类 1256.2.3 利用虚函数支持动态访问 1266.3 对虚函数的进一步讨论 1276.3.1 如何构成虚函数关系 1276.3.2 类的构造、析构与虚函数 1296.3.3 虚函数的内部实现机制 1306.3.4 重载、覆盖和隐藏 1326.3.5 动态造型(dynamic_cast) 1346.4 纯虚函数与抽象类 1356.4.1 纯虚函数 1356.4.2 抽象类 1366.5 多重继承 1386.5.1 多重继承的语法规则 1386.5.2 多重继承中的二义性 1406.5.3 虚继承 1416.6 案例五:公司员工类的设计(三) 1446.6.1 雇员类的定义 1456.6.2 其他类的定义 145思考与练习6 146实验6 149第7章 运算符重载 1507.1 重载运算符的概念与一般方法 1507.1.1 运算符重载是函数重载 1507.1.2 重载运算符的两种方法 1517.1.3 重载运算符的限制 1537.2 重载运算符的设计 1547.2.1 运算符函数的参数 1547.2.2 运算符函数的返回值 1547.3 常见运算符的重载 1557.3.1 重载增量运算符 1557.3.2 重载赋值运算符= 1577.3.3 重载==运算符和!=运算符 1607.3.4 重载下标运算符[] 1607.3.5 重载类型转换运算符() 1617.3.6 重载函数调用运算符与函数 对象 1627.4 案例六:一个向量类的运算符 重载 1647.4.1 向量类定义 1647.4.2 为向量添加运算 166思考与练习7 168实验7 168第8章 流与文件操作 1698.1 理解流机制 1698.1.1 流与文件 1698.1.2 从函数到对象 1698.1.3 源、汇和iostream流控制类 1708.2 构造可流的类 1728.2.1 再谈cout和cin对象 1728.2.2 重载输出运算符<< 1728.2.3 重载输入运算符>> 1738.3 格式控制 1748.3.1 使用流的方法 1758.3.2 使用操控符(Manipulators) 1798.3.3 内存格式化(字符串流) 1828.4 文件流 1838.4.1 文件流的打开与关闭 1838.4.2 文件的读写操作 1858.4.3 二进制文件 1868.4.4 文件的随机访问 1878.5 案例七:一个图书管理系统的 设计 1888.5.1 对象的输入/输出 1898.5.2 管理程序 189思考与练习8 191实验8 191第9章 类模板、容器与泛型算法 1929.1 类模板 1929.1.1 类模板的定义 1929.1.2 使用类模板 1939.1.3 类模板的方法实现 1949.1.4 类模板与普通类之间的相互 继承 1959.1.5 一个模板类实例complex 1969.1.6 设计一个队列模板Queue 1979.2 容器与泛型 1999.2.1 抽象容器类模板 1999.2.2 泛型编程 1999.3 迭代器 2029.3.1 输入迭代器(InputIterator) 2039.3.2 输出迭代器(OutputIterator) 2049.3.3 前向迭代器(ForwardIterator) 2049.3.4 双向迭代器(BidirectionalIterator) 和随机访问迭代器(Random- AccessIterator) 2049.3.5 容器提供的迭代器 2059.3.6 插入迭代器(适配器) 2059.3.7 反向迭代器(reverse_iterator) 2069.4 几种主要容器类与类的方法 2079.4.1 容器类的主要方法 2079.4.2 向量(vector)容器 2089.4.3 列表(list)容器 2099.4.4 双端队列(deque)、栈(stack) 和队列(queue)容器 2109.4.5 映射(map)容器 2109.5 常用的通用算法 2129.5.1 只读算法 2129.5.2 改写元素算法 2139.5.3 元素排序算法 213思考与练习9 214实验9 215第10章 异常处理 21610.1 异常及常规处理方法 21610.1.1 常见的异常 21610.1.2 常规处理方法 21610.2 用try-catch结构处理异常 21810.2.1 try-catch异常处理机制 21810.2.2 异常 21910.2.3 抛出异常 21910.2.4 用try结构监视异常 22010.2.5 用catch结构处理异常 22010.3 合理地处理异常 22210.3.1 异常类设计 22210.3.2 多catch结构组成的异常 捕捉网 22410.3.3 捕捉自己应该处理的异常 22510.3.4 申明异常 227思考与练习10 228实验10 228附录A C Builder集成化环境的使用 229附录B DEV-C 与Visual C 6编程 环境 238附录C 运算符的优先级与结合性 244参考文献 245