C++第四章习题解答文档格式.docx

上传人:b****2 文档编号:1569253 上传时间:2023-05-01 格式:DOCX 页数:36 大小:28.03KB
下载 相关 举报
C++第四章习题解答文档格式.docx_第1页
第1页 / 共36页
C++第四章习题解答文档格式.docx_第2页
第2页 / 共36页
C++第四章习题解答文档格式.docx_第3页
第3页 / 共36页
C++第四章习题解答文档格式.docx_第4页
第4页 / 共36页
C++第四章习题解答文档格式.docx_第5页
第5页 / 共36页
C++第四章习题解答文档格式.docx_第6页
第6页 / 共36页
C++第四章习题解答文档格式.docx_第7页
第7页 / 共36页
C++第四章习题解答文档格式.docx_第8页
第8页 / 共36页
C++第四章习题解答文档格式.docx_第9页
第9页 / 共36页
C++第四章习题解答文档格式.docx_第10页
第10页 / 共36页
C++第四章习题解答文档格式.docx_第11页
第11页 / 共36页
C++第四章习题解答文档格式.docx_第12页
第12页 / 共36页
C++第四章习题解答文档格式.docx_第13页
第13页 / 共36页
C++第四章习题解答文档格式.docx_第14页
第14页 / 共36页
C++第四章习题解答文档格式.docx_第15页
第15页 / 共36页
C++第四章习题解答文档格式.docx_第16页
第16页 / 共36页
C++第四章习题解答文档格式.docx_第17页
第17页 / 共36页
C++第四章习题解答文档格式.docx_第18页
第18页 / 共36页
C++第四章习题解答文档格式.docx_第19页
第19页 / 共36页
C++第四章习题解答文档格式.docx_第20页
第20页 / 共36页
亲,该文档总共36页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

C++第四章习题解答文档格式.docx

《C++第四章习题解答文档格式.docx》由会员分享,可在线阅读,更多相关《C++第四章习题解答文档格式.docx(36页珍藏版)》请在冰点文库上搜索。

C++第四章习题解答文档格式.docx

(2)名字空间域(namespacescope)

(3)类域(classscope)

(4)局部域

(5)名字空间域

(6)namespace

(7)名字空间名

(8)可以直接被使用

(9)域

4.1.5引用通常用作函数的

(1)和

(2)。

对数组只能引用(3)不能引用(4)。

(1)参数

(2)返回值

(3)数组元素

(4)数组名本身

4.1.6构造函数的任务是

(1)。

构造函数无

(2)。

类中可以有(3)个构造函数,它们由(4)区分。

如果类说明中没有给出构造函数,则C++编译器会(5)。

拷贝构造函数的参数是(6),当程序没有给出复制构造函数时,系统会自动提供(7)支持,这样的复制构造函数中每个类成员(8)。

(1)初始化数据成员

(2)函数返回类型说明

(3)多

(4)不同的参数表

(5)自动给出一个默认的构造函数

(6)同一类对象的引用

(7)默认的的复制构造函,称为默认的按成员语义支持。

(8)被依次复制

4.1.7一个类有

(1)个析构函数。

(2)时,系统会自动调用析构函数。

(1)一

(2)对象注销时

4.1.8运算符重载时,其函数名由

(1)构成。

成员函数重载双目运算符时,左操作数是

(2),右操作数是(3)。

(1)关键字operator和该运算符

(2)对象

(3)该函数的参数

4.1.9面向过程的程序设计中程序模型描述为

(1),面向对象程序设计的程序模型可描述为

(2)。

(1)“程序=算法+数据结构”。

其数据与数据处理是分离的。

(2)程序=(对象+对象+……+对象)+消息;

对象=(算法+数据结构)。

面向对象设计将数据和对数据的操作方法放在一起,形成一个相对独立的整体——对象(Object),并通过简单的接口与外部联系。

对象之间通过消息(Message)进行通讯。

4.2简答题

4.2.1简单解释什么是面向对象程序设计的封装性。

答:

对象是一个封装体,在其中封装了该对象所具有的属性和操作。

对象作为独立的基本单元,实现了将数据和数据处理相结合的思想。

此外,封装特性还体现在可以限制对象中数据和操作的访问权限,从而将属性“隐藏”在对象内部,对外只呈现一定的外部特性和功能。

封装性增加了对象的独立性,C++通过建立数据类型——类,来支持封装和数据隐藏。

一个定义完好的类一旦建立,就可看成完全的封装体,作为一个整体单元使用,用户不需要知道这个类是如何工作的,而只需要知道如何使用就行。

另一方面,封装增加了数据的可靠性,保护类中的数据不被类以外的程序随意使用。

这两个优点十分有利于程序的调试和维护。

4.2.2C++编译器怎样对标识符进行解析

编译器对标识符的解析分两步,第一步查找在声明中用到的标识符,特别是函数成员声明中用到的参数类型,第二步是函数成员体内的标识符。

4.2.3为什么说类与对象的概念是客观世界的反映?

客观世界的事物都具有某些属性和行为(或操作),具有相同属性和行为的事物可以归属于一类,用分类的方法可以提高认识事物的效率。

C++中定义的类则是通过抽象的方法将某一类事物共有的静态特征(属性)和动态特征(行为)概括出来并加以描述,而对象是类的具体实现,所以说类与对象的概念是客观世界的反映。

4.2.4什么叫类域?

为什么说类域是抽象的?

类域是类体所包括的范围。

每个类定义都引入了一个独立的类域,在类域中说明的标识符仅在该类的类域中有效。

由于类只是一个说明,看上去有数据,有函数,有类型定义,但是它并非实体,不分配内存,当然也不能运行。

所以说类域是抽象的。

4.2.5引用作为函数参数时为什么能实现两个实参之间的数据交换?

为什么对应实参不能为引用?

为什么返回值为引用的函数可以作为左值?

引用变量是其关联变量的别名,二者在内存中占据同一个存储单元。

在一个以引用作为参数的函数中,交换两个参数的值,实际上就是交换两个实参的值。

如果函数的参数是引用,调用时需要取得实参的地址,而实参如果已经是一个地址,再进行引用将产生错误,故对应实参不能为引用。

函数返回引用实际是指明(返回)了相应的关联变量,所以声明返回值为引用的函数实际上是将关联变量作为左值参与运算。

4.2.6什么是缺省的构造函数?

缺省的构造函数最多可以有多少个?

如果在类定义中不显式地定义构造函数,C++编译器会自动产生一个缺省的构造函数,不过该函数不做具体的初始化工作。

只要构造函数是无参的或者只要各参数均有缺省值的,C++编译器都认为是缺省的构造函数。

缺省的构造函数只能有一个。

4.2.7拷贝构造函数用于哪三个方面?

(1)用类的一个对象去初始化该类的另一个对象时使用。

(2)当函数的形参是类的对象,调用函数时,进行形参与实参结合时使用。

(3)当函数的返回值是类对象,函数执行结束返回调用者时使用。

4.2.8写出含有对象成员的类的构造函数的格式,并做简单说明。

C++中对含对象成员的类对象的构造函数有固定的格式:

类名:

构造函数名(参数总表):

对象成员1(参数名表1),对象成员2(参数名表2),……对象成员n(参数名表n){……}

冒号后用逗号隔开的是要初始化的对象成员,附在后面的参数名表1,…,参数名表n依次为调用相应对象成员所属的构造函数时的实参表。

这些表中的参数通常来自冒号前的参数总表,但没有类型名。

4.2.9所有类对象未重载的赋值运算符“=”是怎样工作的?

为什么它可以进行连续赋值?

对所有的类对象,未重载的赋值运算符“=”称作缺省的按成员拷贝赋值操作符,同类对象之间可以用“=”直接拷贝。

因为缺省的赋值操作返回一个对象的引用,所以它可以进行连续赋值。

为什么在友元函数的函数体内访问对象成员时,必须用对象名加运算符“.”再加对象成员名?

友元函数不是类的成员函数,在函数体中访问对象的成员,必须用对象名加运算符“.”加对象成员名。

这一点和一般函数一样。

重载复数运算符+时,采用下面友元函数声明:

friendComplexoperator+(Complex&

c1,Complex&

c2);

为什么不能用于“实数+复数”?

怎样改进才能适用?

为什么?

使用引用类型变量作为运算符重载函数的参数,身为左值的实数类型实参不能被转换为复数,编译时无法通过。

添加const说明,使实数到复数的转换隐式地在一份拷贝上进行,则可以实现“实数+复数”运算。

修改后的说明为:

friendComplexoperator+(constComplex&

c1,constComplex&

类的静态数据成员与函数中的静态成员有何异同?

类的静态成员为其所有对象共享,不管有多少对象,静态成员只有一份存于公用内存中,为该类所有对象公用。

函数中的静态变量也位于公用内存中,不随函数调用而重新分配,所以总是保留上次进入并执行该函数后留下的信息。

C++中结构、联合与类三者间有何异同?

在C++中结构(structure)与类几乎是完全一样的类型,差别仅仅在于缺省情况下结构的成员为公有的。

联合(union)是C++的导出数据类型,在语法与功能上类似于结构,二者的区别是:

结构变量的各成员同时被分配了各自独立的内存区,而联合变量的各个成员的存储开始地址都相同,所以在任一时刻联合变量只能存储一个成员。

对象的第一特征是封装,那么由对象组成的面向对象的程序怎样建立各对象之间的有效联系?

面向对象程序的组织与面向过程有什么不同?

因为对象的操作主要用来响应外来消息并为其他对象提供服务,所以面向对象的程序利用消息传递机制来建立各对象之间的有效联系,协调各对象的运行。

一个对象可以向其他对象发送消息以请求服务,也可以响应其他对象传来的消息,完成自身固有的某些操作,从而服务于其他对象。

面向过程的程序是模块化的,模块的组织具有分层结构特点,层与层之间是调用关系。

面向对象程序是由一个个封装的对象组成,而对象是由紧密结合在一起的算法和数据结构组成。

对象之间是相互请求和相互协作的关系。

简叙Windows下应用程序的运行方式。

Windows系统支持多个应用程序同时执行,在界面形式上,它支持多个窗口同时活动。

它的运行机制是“消息传递和事件驱动(messagebasedandeventdriven)”。

Windows系统使用事件驱动的编程模式。

所谓事件的含义非常广泛。

输入设备的动作,如敲打键盘、按鼠标等会产生一系列的事件(注意不是一个事件)。

操作系统所作的一举一动也被当作某种类型的事件,应用程序也会产生各种事件。

事件用来标识发生的某件事情。

Windows系统对于应用程序环境中发生的每一个事件都会以对应的某种消息的形式标识,并放入相应的Windows建立的消息队列中,然后由对应的应用程序或窗口函数去处理。

窗口函数处理是分层的,前面处理不了的送到后面,最后处理不了剩下的全由缺省的窗口函数处理。

类的成员函数在什么情况下应该定义为私有的?

这样做的目的是什么?

除接口函数和创建本类对象的构造函数和撤消该对象的析构函数外。

其余成员函数应该定义为私有的,这是开发类时故意对外隐蔽起来的操作,而这些往往是最复杂最关键的部分。

类中故意的隐藏也为以后的升级扩展留下了余地,只要接口不变,内部再变,也不必修改原来的程序,就象MFC(微软基础类)升级后,由MFC底层类所编的程序完全不必修改,自动升级。

二.编程与综合练习题

4.3构造一个日期时间类(Timedate),数据成员包括年、月、日和时、分、秒,函数成员包括设置日期时间和输出时间,其中年、月请用枚举类型,并完成测试。

(包括用成员函数和用普通函数)

解:

本题要求仅是定义类的练习,并非实用的提供日期时间的程序。

实用的日期时间程序见附录二的日期时间函数。

#include<

iostream>

iomanip>

usingnamespacestd;

enumYR{Y2000,Y2001,Y2002,Y2003,Y2004,Y2005};

//

enumMT{Jan,Feb,Mar,Apr,May,Jun,Jul,Aug,Sep,Oct,Nov,Dec};

classTimedate{

private:

YRyear;

MTmonth;

intdate;

inthh;

intmm;

intss;

public:

Timedate(){year=Y2000;

month=Jan;

date=1;

hh=0;

mm=0;

ss=0;

}

Timedate(YRa,MTb,intc){

year=a;

month=b;

date=c;

hh=12;

mm=30;

}

voidgetdate(YR&

MT&

int&

);

//使用引用一次取得3个数值

voidgettime(int&

voidputdate(YR,MT,int);

voidputtime(int,int,int);

voidlist();

};

voidTimedate:

getdate(YR&

y,MT&

m,int&

d){

y=year;

m=month;

d=date;

gettime(int&

a,int&

b,int&

c){

a=hh;

b=mm;

c=ss;

putdate(YRa,MTb,intc){

year=a;

month=b;

date=c;

puttime(inta,intb,intc){

hh=a;

mm=b;

ss=c;

list(){//成员函数,直接访问私有的数据成员

cout<

<

"

year/month/date:

;

switch(year){

caseY2000:

cout<

2000"

break;

caseY2001:

2001"

caseY2002:

2002"

caseY2003:

2003"

caseY2004:

2004"

caseY2005:

2005"

switch(month){

caseJan:

'

/'

Jan"

caseFeb:

Feb"

caseMar:

Mar"

caseApr:

Apr"

caseMay:

May"

caseJun:

Jun"

caseJul:

Jul"

caseAug:

Aug"

caseSep:

Sep"

caseOct:

Oct"

caseNov:

Nov"

caseDec:

Dec"

date<

endl;

hour:

minite:

second:

hh<

mm<

ss<

voidlist(Timedatetd){//普通函数,通过接口函数访问私有的数据成员

td.getdate(year,month,date);

switch(month){//,,,,,,,,

td.gettime(hh,mm,ss);

}

intmain(){

TimedateA(Y2004,Mar,3),B;

A.list();

B.list();

B.putdate(Y2005,Oct,18);

B.puttime(17,30,00);

list(B);

return0;

4.4设计并测试一个矩形类(Rectangle),属性为矩形的左下与右上角的坐标,矩形水平放置。

操作为计算矩形周长与面积。

测试包括用成员函数和普通函数。

这里的矩形的4边分别与x轴y轴平行,为最简单的情况。

注意参数有缺省值的函数的声明和定义格式。

cmath>

classRectangle{

doubleleft,top;

doubleright,bottom;

Rectangle(doublel=0,doublet=0,doubler=0,doubleb=0);

~Rectangle(){};

//析构函数,在此函数体为空

voidAssign(doublel,doublet,doubler,doubleb);

doublegetLeft(){returnleft;

}//以下四个函数皆为内联成员函数

doublegetRight(){returnright;

doublegetTop(){returntop;

doublegetBottom(){returnbottom;

voidShow();

doubleArea();

doublePerimeter();

//构造函数,带缺省参数,缺省值为全0,在声明中指定

Rectangle:

Rectangle(doublel,doublet,doubler,doubleb){

left=l;

top=t;

right=r;

bottom=b;

voidRectangle:

Assign(doublel,doublet,doubler,doubleb){//赋值

Show(){//成员函数直接使用私有的数据成员

left-toppointis("

left<

"

top<

)"

\n'

right-bottompointis("

right<

bottom<

doubleRectangle:

Area(){

returnfabs((right-left)*(bottom-top));

Perimeter(){

return2*(fabs(right-left)+fabs(bottom-top));

Rectanglerect;

rect.Show();

rect.Assign(100,200,300,400);

Rectanglerect1(0,0,200,200);

rect1.Show();

Rectanglerect2(rect1);

rect2.Show();

面积"

rect.Area()<

\t'

周长"

rect.Perimeter()<

4.5定义一个圆类(Circle),属性为半径(radius)、圆周长和面积,操作为输入半径并计算周长、面积,输出半径、周长和面积。

要求定义构造函数(以半径为参数,缺省值为0,周长和面积在构造函数中生成)和拷贝构造函数。

通常所有数据成员都在构造函数中赋初值。

拷贝构造函数以本类的引用为参数。

#include<

classCircle{

doubler,Area,Circumference;

Circle(doublea=0);

Circle(Circle&

voidSetR(doubleR);

doubleGetR(){returnr;

doubleGetAreaCircle(){returnArea;

doubleGetCircumference(){returnCircumference;

Circle:

Circle(doublea){

r=a;

Circle(Circle&

cl){

r=cl.r;

Area=cl.Area;

Circumference=cl.Circumference;

voidCircle:

SetR(doubleR){

r=R;

Circumference=2*r*3

Circlecl1

(2),cl2,cl3=cl1;

圆半径:

cl3.GetR()<

圆周长:

cl3.GetCircumference()

<

圆面积:

cl3.GetAreaCircle()<

cl2.SetR

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 法律文书 > 调解书

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2