面向对象程序设计C++复习题Word下载.docx

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

面向对象程序设计C++复习题Word下载.docx

《面向对象程序设计C++复习题Word下载.docx》由会员分享,可在线阅读,更多相关《面向对象程序设计C++复习题Word下载.docx(48页珍藏版)》请在冰点文库上搜索。

面向对象程序设计C++复习题Word下载.docx

13.类的析构函数的作用是()。

A.一般成员函数B.类的初始化C.对象初始化D.删除对象之前的善后工作

14.下列对基类和派生类关系的描述中,错误的是()。

A.派生类是基类的具体化B.派生类是基类的子集

C.派生类是基类定义的延续D.派生类是基类的组合

15.下列对派生类的描述中,错误的是()。

A.一个派生类可以作为另一个派生类的基类B.派生类至少有一个基类

C.派生类的缺省继承方式是privateD.派生类只继承了基类的公有成员和保护成员

 

16.下列对继承的描述中,错误的是()。

A.析构函数不能被继承

B.派生类也是基类的组合

C.派生类的成员除了它自己的成员外,还包含了它的基类的成员

D.派生类中继承的基类成员的访问权限到派生类保持不变

17.派生类的对象对它的基类成员中()是可以访问的。

A.公有继承的公有成员B.公有继承的私有成员

C.公有继承的保护成员D.私有继承的公有成员

18.下列说法错误的是()。

A.公有继承的基类中的public成员在派生类中仍是public的

B.公有继承的基类中的private成员在派生类中仍是private的

C.私有继承的基类中的public成员在派生类中仍是private的

D.保护继承的基类中的public成员在派生类中仍是protected的

19.下面叙述错误的是()。

A.基类的protected成员在派生类中仍然是protected

B.基类的protected成员在public派生类中仍然是protected的

C.基类的protected成员在private派生类中是private的

D.基类的protected成员不能被派生类的对象访问

20.设置虚基类的声明中,正确的是()。

A.简化程序B.消除二义性C.提高运行效率D.减少目标代码

21.关于虚函数的描述中,正确的是()。

A.虚函数是一个静态成员函数

B.虚函数是一个非成员函数

C.虚函数即可以在函数说明定义,也可以在函数实现时定义

D.派生类的虚函数与基类中对应的虚函数具有相同的参数个数和类型

22.下列描述中,()是抽象类的特征。

A.可以说明虚函数B.可以进行构造函数重载

C.可以定义友元函数D.不能说明其对象

23.静态数据成员的初始化是在()中进行的。

A.构造函数B.任何成员函数

C.所属类D.全局区

24.当将一个类A或函数f()说明为另一个类B的友元后,类A或函数f()能够直接访问类B的()。

A.只能是公有成员B.只能是保护成员

C.只能是除私有成员之外的任何成员D.具有任何权限的成员

25.在重载一个运算符时,其参数表中没有任何参数,这表明该运算符是()。

A.作为友元函数重载的1元运算符B.作为成员函数重载的1元运算符

C.作为友元函数重载的2元运算符D.作为成员函数重载的2元运算符

26.关于运算符重载,下列说法正确的是()。

A.重载时,运算符的优先级可以改变。

B.重载时,运算符的结合性可以改变。

C.重载时,运算符的功能可以改变。

D.重载时,运算符的操作数个数可以改变。

27.从一个基类派生出的各个类的对象之间()。

A.共享所有数据成员,每个对象还包含基类的所有属性

B.共享部分数据成员,每个对象还包含基类的所有属性

C.不共享任何数据成员,但每个对象还包含基类的所有属性

D.共享部分数据成员和函数成员

28.C++的继承性允许派生类继承基类的()。

A.部分特性,并允许增加新的特性或重定义基类的特性

B.部分特性,但不允许增加新的特性或重定义基类的特性

C.所有特性,并允许增加新的特性或重定义基类的特性

D.所有特性,但不允许增加新的特性或重定义基类的特性

29.派生类的成员函数可以直接访问基类的()成员。

A.所有B.公有和保护C.保护和私有D.私有

30.当派生类中有和基类一样名字的成员时,一般来说,()。

A.将产生二义性B.派生类的同名成员将覆盖基类的成员

C.是不能允许的D.基类的同名成员将覆盖派生类的成员

31.关于纯虚函数和抽象类的描述中,错误的是()。

A.纯虚函数是一种特殊的虚函数,它没有具体的实现

B.抽象类是指具体纯虚函数的类

C.一个基类中说明有纯虚函数,该基类派生类一定不再是抽象类

D.抽象类只能作为基类来使用,其纯虚函数的实现由派生类给出

32.如果一个类至少有一个纯虚函数,那么就称该类为()。

A.抽象类B.虚函数C.派生类D.以上都不对

33.要实现动态联编,必须通过()调用虚函数。

A.对象指针B.成员名限定C.对象名D.派生类名

34.以下()成员函数表示虚函数。

A.virtualintvf(int);

B.voidvf(int)=0;

C.virtualvoidvf()=0;

D.virtualvoidvf(int){};

40.下面描述中,正确的是()。

A.virtual可以用来声明虚函数

B.含有纯虚函数的类是不可以用来创建对象的,因为它是虚基类

C.即使基类的构造函数没有参数,派生类也必须建立构造函数

D.静态数据成员可以通过成员初始化列表来初始化

35.在成员函数中进行双目运算符重载时,其参数表中应带有()个参数。

A.0B.1C.2D.3

36.在重载一运算符时,若运算符函数的形参表中没有参数,则不可能的情况是()。

A.该运算符是一个单目运算符。

B.该运算符函数有一个隐含的参数this。

C.该运算符函数是类的成员函数。

D.该运算符函数是类的友元函数。

37.下面对于友元函数描述正确的是()。

A.友元函数的实现必须在类的内部定义

B.友元函数是类的成员

C.友元函数破坏了类的封装性和隐藏性

D.友元函数不能访问类的私有成员

38.为了使类中的某个成员不能被类的对象通过成员操作符访问,则不能把该当成员的访问权限定义为()。

A.publicB.protectedC.privateD.ststic

39.下面对静态数据成员的描述中,正确的是()。

A.静态数据成员是类的所有对象共享的数据

B.类的每一个对象都有自己的静态数据成员

C.类的不同对象有不同的静态数据成员值

D.静态数据成员不能通过类的对象调用

40.C++类体系中,不能被派生类继承的有()。

A.构造函数B.虚函数C.静态成员函数D.赋值操作函数

41下列虚基类的声明中,正确的是()。

A.classvirtualB:

publicAB.virtualclassB:

publicA

C.classB:

publicAvirtualD.classB:

virtualpublicA

42在下面的表达式中,不表示虚继承的是()。

A.virtualpublicB.publicvirtual

C.publicD.virtual

43.下列关于动态联编的描述中,错误的是()。

A.动态联编是以虚函数为基础

B.动态联编是运行时确定所调用的函数代码的

C.动态联编调用函数操作是指向对象的指针或对象引用D.动态联编是在编译时确定操作函数的

44.下面4个选项中,()是用来声明虚函数的。

A.virtualB.publicC.usingD.false

45.编译时的多态性可以通过使用()获得。

A

 A.虚函数和指针B.重载函数和析构函数

C.虚函数和对象D.虚函数和引用

二.填空题

1.重载插入运算符<

<

时,其运算符函数的返回值类型应当是ostream&

2.派生类可以定义其基类中不具备的数据和操作。

3.对象将其大部分实现细节隐藏起来,这种机制称为封闭。

4.建立类和类的对象时,系统对类不分配内存,系统对对象分配内存。

5.基类和派生类的关系称为继承和派生。

6.当保护继承时,基类的公有或保护成员在派生类中成为保护成员,派生类对象不能直接访问基类的任何成员。

7.C++支持两种多态性:

编译时的多态性(重载)和运行时的多态性(虚函数)。

8.在C++中定义类时,通常是利用变量描述对象的“特征”;

利用函数描述对象的“行为”。

9.假定用户为类AB定义了一个构造函数"

AB(intaa,char*bb=NULL):

a(aa),b(bb){}”,则该类中至少包含有2个数据成员。

10.类是对象的抽象 ;

而对象则是类的具体实例。

11.如果不做特殊说明,类成员的默认访问权限是私有;

结构成员的默认访问权限是公有。

12.在定义对象的同时初始化其成员变量,需要利用构造函数,用于初始化变量的值可以是固定的常量,也可以通过参数获得。

13.在私有继承关系下,基类的公有成员和保护成员将成为派生类中的私有成员,它们只能由派生类的成员函数来访问;

基类的私有成员将成为派生类中的不可访问的成员。

14.在保护继承中,基类中的公有成员、保护成员是可见的。

15.面向对象方法构造的系统,其基本单位是对象。

16.生成一个派生类对象时,先调用基类的构造函数,然后调用派生类的构造函数。

17.AAoperator+(AAx)表示为运算符+重载。

18.若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上类名和两个冒号分隔符。

19.若采用x.abc(y)表达式调用一个成员函数,在成员函数中使用的*this就代表了类外的x对象。

20.假定用户没有给一个名为AB的类定义析构函数,则系统为其定义的析构函数为~AB(){}。

21.类的成员按访问权限可分为三类:

公有、私有、保护。

22.在一个类中定义复制构造函数的目的,是为了当利用该类的一个对象初始化另一个对象时,能够避免这两个对象的同一指针同时指向同一块地址。

23.假定AB为一个类,则执行“ABa[10];

”语句时,系统自动调用该类构造函数的次数为10。

24.假定要把aa定义为AB类中的一个常量整数型数据成员,则定义语句为constintaa;

25.假定AB为一个类,则该类的复制构造函数的函数头为AB(AB&

)。

26.假定AB为一个类,该类中含有一个指向动态数组空间的指针成员pa,则在该类的析构函数中应该包含有一条deletepa语句。

27.静态成员函数只能访问类的静态数据成员,非静态成员函数访问类的非静态数据成员。

28.一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明必须在函数名前加上friend的限定。

29.一个单目运算符作为类的成员函数重载时有0个参数;

如果作为友元函数重载,则有1个参数。

30.若多个基类及其派生类中都定义了同名函数成员,要访问相应函数时,就需要在函数名前加上基类名和类区分符。

31.若要保证一个公共的基类在派生类中只产生一个基类子对象,则必须都以virtual的方式直接继承它。

32.引进虚基类的根本目的是为了消除二义性。

33.在每个成员函数中,隐含的第一个参数的参数名为this指针。

三.写出下列程序的运行结果

(1)#include<

iostream.h>

structab

{

chara[5];

floatb;

};

voidmain()

abx={"

Li"

89.6};

cout<

x.a<

'

\t'

x.b<

endl;

}

Li89.6

(2)#include<

{chara;

voidf(ab&

y)

{y.a='

W'

;

y.b=90.5;

abx={'

L'

89.5};

f(x);

W90.5

(3)#include<

#include<

string.h>

classA{

chara;

public:

A(char*s){

a=newchar[strlen(s)+1];

strcpy(a,s);

a<

}

~A(){delete[]a;

"

Destructor!

voidmain()

{Ax("

LiMing"

);

A y("

Zhang"

 }

(4)#include<

intn=0;

inta;

A(intaa=0){a=aa;

n++;

~A(){n--;

cout<

n<

voidshow(){cout<

{Aa;

a.show();

{Ax[2];

x[1].show();

a.show();

1

3

2

(5)#include<

classA

{inta,b;

                    

public:

A()

{a=b=0;

'

b<

A(intaa,intbb)

{a=aa;

b=bb;

};

{Ax,y(10,5);

(6)#include<

classBB

BB(inti=0,intj=1){a=i;

b=j;

BBoperator+(BBc)

{BBd;

d.a=a+c.a*10;

d.b=b+c.b*10;

returnd;

BBoperator-(BBc)

d.a=a*c.a;

d.b=b*c.b;

voidshow()

{cout<

('

'

)'

{BBx(2,6),y(5,5),z;

z=x+y;

z.show();

z=x-y;

(7)#include<

classEX

{intx,y;

EX(inti=0,intj=1){x=i;

y=j;

EXoperator*(EXz)

{EXd;

d.x=x*z.x;

d.y=y*z.y;

EXoperator/(EXc)

d.x=x-c.x;

d.y=y-c.y;

{EXa(30,10),b(2,5),c;

c=a*b;

c.show();

c=a/b;

(8)#include<

classPoint{

intx,y;

Point(){x=1;

y=1;

~Point(){cout<

Point"

x<

y<

isdeleted."

{

Pointa;

(9)#include<

#include<

conio.h>

intcount=0;

classPoint

{intx,y;

Point(){x=1;

y=1;

count++;

~Point(){count--;

};

voiddisplay()

{

cout<

Thereare"

count<

points."

{Pointa;

display();

{Pointb[5];

display();

(10)#include<

classEX1

EX1()

{a=b=1;

EX1(intaa,intbb=100)

EX1x,y(10,2);

EX1z(200);

(11)#include<

classCsample

{inti;

Csample()

{cout<

constructor1"

<

i=0;

Csample(intval)

Constructor2"

i=val;

voidDisplay()

i="

i<

~Csample()

Destructor"

}

Csamplea,b(10);

a.Display();

b.Display();

(12)#include<

private:

inti;

staticintk;

Csample();

voidDisplay();

intCsample:

:

k=0;

Csample:

Csample()

k++;

voidCsample:

Display()

k="

k<

voidmain()

Csamplea,b;

a.Display();

b.Display();

(13)#include<

#include<

structA

charc[20];

floatf;

voidf(A&

t)

strcpy(t.c,”MALIANG”);

t.f=70.5;

{Az={“LIMING”,77.5};

f(z);

cout<

z.c<

z.f<

(14)#include<

classCsample

~Csample();

Csample:

{cout<

Constructor"

"

voidCsample:

Display()

~Csample()

{Csamplea;

5月13日

15.#include<

classCroot

{public:

intsmall;

Croot(){small=2;

”CalledConstructor1.\n”;

Croot(intn){small=n;

”CalledConstructor2.\n”;

voidshowsmall(){cout<

small="

small<

classCder1:

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

当前位置:首页 > 人文社科 > 法律资料

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

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