本文档如对你有帮助,请帮忙下载支持!
C++面向对象程序设计教程课后题答案
什么是面向对象程序设计 ?
面向对象程序设计是一种新的程序设计范型 . 这种范型的主要特征是 : 程序=对象+消息 面向对象程序的基本元素是对象。 主要结构特点是: 第一, 第二,
程序一般由类的定义和类的使用两部分组成;
程序中的一切操作都是通过向对象发送消息来实现的。 什么是对象 ?什么是类 ?对象与类之间的关系是什么 ?
1.2
对象是描述其属性的数据以及对这些数据施加的一组操作封装在一起构成的统 一体。 类就是具有相同的数据和相同的操作的一组对象的集合, 也就是说, 类是对具有 相同数据结构和相同操作的一类对象的描述。
类和对象之间的关系是抽象和具体的关系。类是多个对象进行综合抽象的结果, 一个对象是类的一个实例。
1.3
现实世界中的对象有哪些特征?请举例说明。
现实世界中的对象具有以下特征:
1) 2) 3)
每一个对象必须有一个名字以区别于其他对象; 用属性来描述对象的某些特征;
有一组操作,每组操作决定对象的一种行为;
4)
对象的行为可以分为两类:一类是作用于自身的行为,另
一类是作用于其他对象的行为。
例如一个教师是一个对象。 每个教师对象有自己的名字来和别的教师区别。 教师 具有编号,姓名,年龄,职称,专业等属性。教师拥有走路,吃饭,授课等行为 操作。走路,吃饭是作用于自身的行为,授课是作用于其他对象的行为。
本文档如对你有帮助,请帮忙下载支持!
1.4
什么是消息?消息具有什么性质?
一个对象向另一个对象发出的请求成为“消息”。 消息具有以下
3 个性质:
同一个对象可以接收不同形式的多个消息,做出不同的相
1)
应;
2) 以是不同
的;
相同形式的消息可以传递给不同的对象,所做出的响应可
3) 不响
应。
对消息的响应并不是必须的,对象可以响应消息,也可以
1.5
什么是抽象和封装?请举例说明。
抽象是将有关事物的共性归纳、集中的过程。
例如:把所有具有大学生学籍的人归为一类, 成为“大学生”, 这就是一个抽象。
封装是指把数据和实现操作的代码集中起来放在对象内部, 并尽可能隐藏对象的 内部细节。 例如:每一台洗衣机都有出厂日期、机器编号等属性,也有启动、暂停、选择等 操作。人们在使用洗衣机的时候只需要按下对应的按钮, 而不用关心具体的内部 实现。这就是封装。
1.6
什么是继承?请举例说明。
继承就是允许派生类使用基类的数据和操作, 同时,派生类还可以增加新的操作 和数据。 例如:哺乳动物是一种热血、有毛发、用奶哺育幼崽的动物; 狗是有犬牙、食 肉、特定的骨骼结构、群居的哺乳动物。 狗就继承了哺乳动物。
1.7
若类之间具有继承关系,则他们之间具有什么特征?
若类之间具有继承关系,则他们之间具有下列几个特征:
1) 2)
码);
类间具有共享特征(包括数据和操作代码的共享); 类间具有差别或新增部分(包括非共享的数据和操作代
3) 类具有层次结构。
本文档如对你有帮助,请帮忙下载支持!
1.8
什么是单继承、多继承?请举例说明。
单继承是指每个派生类只直接继承了一个基类的特征。例如狗继承自哺乳动物。
多继承是指多个基类派生出一个派生类的继承关系。 比如玩具车同时继承自玩具 和车。
1.9
什么是多态?请举例说明。
多态是指不同的对象收到相同的消息时执行不同的操作。
例如,有一个窗口类对象,还有一个棋子类对象。当我们发出“移动”消息时, 两个对象的行为不同。
1.10
面向对象程序设计的主要优点是什么?
可提高程序的重用性; 可控制程序的复杂性; 可改善程序的可维护性;
能够更好地支持大型程序设计;
增强了计算机处理信息的范围; 能够很好地适应新的硬件环境。
1. 2. 3. 4. 5.
2.1简述C++勺主要特点。 1)
C++是C的超集,保持与C的兼容。
保持了 C的简洁、高效和接近汇编语言等特点,并对
2) C的
功能作了不少扩充。用C++编写的程序比C更安全,可读性更好,代码结构更为 合理。
3)
程序质量高。
2.2 #include
using namespacestd; int main()
{
增加了面向对象机制。
int a, b, d, min;
cout << \min = a > b ? b : a;
本文档如对你有帮助,请帮忙下载支持!
for (d = 2; d < min; d++)
if (((a % d) == 0) && ((b % d ) == if (d == min)
cout << \
}
0)) break;
cout << \
2.3 有效
2.4 没有函数声明;
函数定义没有写返回值类型。
2.5
1)等价,函数声明可以省略参数的名字。
2)不等价,第二个的函数定义不能省略参数的名字。
2.6-2.10 CDAAB 2.11-2.15 ACBDC 2.16-2.17 DC 2.18 101 2.19 10 10 2.20 10 20 2.21举例说明可以使用const替代#define以消除#define的不安全性。 #include
本文档如对你有帮助,请帮忙下载支持!
using namespacestd; int main() {
int #define #define
a = 1; T1 a+a T2 T1-T1
cout <<
上面这个程序,初看应该输出 T2 is 0
但是实际上,得出 T2 is 2
如果把 #define 换成 const , 则可以输出想要的结果。
2.22 用动态分配空间的方法, 配计算 Fibonacci 数列的前 20 的空间中。
#include
{
int
*pi =
*pi = new int [ 20]; pi[
1;
for
1] = 1; (int i = 2; i < 20; i++) pi[i] = pi[i -
2] + pi[i - 1];
\
}
return 0;
2.23 重载 sroot 函数,输出一个数的二次方根。 #include
{
return ( double )sqrt(( double )num); } double sroot( long num)
{
return ( double )sqrt(( double )num); }
项,并存储到动态分