C++填空选择题.docx
《C++填空选择题.docx》由会员分享,可在线阅读,更多相关《C++填空选择题.docx(57页珍藏版)》请在冰豆网上搜索。
C++填空选择题
C++程序设计模拟试卷
(一)
一、单项选择题
1.编写C++程序一般需经过的几个步骤依次是()
A.编辑、调试、编译、连接
B.编辑、编译、连接、运行
C.编译、调试、编辑、连接
D.编译、编辑、连接、运行
答案:
B
解析:
(P21)经过编辑、编译、连接和运行四个步骤。
编辑是将C++源程序输入计算机的过程,保存文件名为cpp。
编译是使用系统提供的编译器将源程序cpp生成机器语言的过程,目标文件为obj,由于没有得到系统分配的绝对地址,还不能直接运行。
连接是将目标文件obj转换为可执行程序的过程,结果为exe。
运行是执行exe,在屏幕上显示结果的过程。
2.决定C++语言中函数的返回值类型的是()
A.return语句中的表达式类型
B.调用该函数时系统随机产生的类型
C.调用该函数时的主调用函数类型
D.在定义该函数时所指定的数据类型
答案:
D
解析:
(P51)函数的返回值类型由定义函数时的指定的数据类型决定的。
A项的表达式的值要转换成函数的定义时的返回类型。
3.下面叙述不正确的是()
A.派生类一般都用公有派生
B.对基类成员的访问必须是无二义性的
C.赋值兼容规则也适用于多重继承的组合
D.基类的公有成员在派生类中仍然是公有的
答案:
D
解析:
(P136)继承方式有三种:
公有、私有和保护。
多继承中,多个基类具有同名成员,在它们的子类中访问这些成员,就产生了二义性,但进行访问时,不能存在二义性。
赋值兼容规则是指派生类对象可以当作基类对象使用,只要存在继承关系,所以单继承或多继承都适用。
基类中的公有成员采用私有继承时,在派生类中变成了私有成员,所以D项错误。
4.所谓数据封装就是将一组数据和与这组数据有关操作组装在一起,形成一个实体,这实体
也就是()
A.类
B.对象
C.函数体
D.数据块
答案:
A
解析:
(P39)类即数据和操作的组合体,数据是类的静态特征,操作是类具有的动作。
5.在公有派生类的成员函数不能直接访问基类中继承来的某个成员,则该成员一定是基类中
的()
A.私有成员
B.公有成员
C.保护成员
D.保护成员或私有成员
答案:
A
解析:
(P133)在派生类中基类的保护或者基类公有都可以直接访问,基类的私有成员只能是基类的成员函数来访问。
所以选择A项。
6.对基类和派生类的关系描述中,错误的是()
A.派生类是基类的具体化
B.基类继承了派生类的属性
C.派生类是基类定义的延续
D.派生类是基类的特殊化
答案:
B
解析:
(P129)派生类的成员一个是来自基类,一个来自本身,所以派生类是基类的扩展,也是基类的具体化和特殊化,派生类是对基类扩展。
B项基类不能继承派生类成员,所以错误。
7.关于this指针使用说法正确的是()
A.保证每个对象拥有自己的数据成员,但共享处理这些数据的代码
B.保证基类私有成员在子类中可以被访问。
C.保证基类保护成员在子类中可以被访问。
D.保证基类公有成员在子类中可以被访问。
答案:
A
解析:
(P86)this指针是隐藏的,可以使用该指针来访问调用对象中的数据。
基类的成员在派生类中能否访问,与继承方式有关,与this没有关系。
所以选择A项。
8.所谓多态性是指()
A.不同的对象调用不同名称的函数
B.不同的对象调用相同名称的函数
C.一个对象调用不同名称的函数
D.一个对象调用不同名称的对象
答案:
B
解析:
(P167)多态性有两种静态多态性和动态多态性,静态多态性是指调用同名函数,由于参数的不同调用不同的同名函数;动态多态性是指不同对象调用同名函数时,由于对象不同调用不同的同名函数。
多态性肯定具有相同的函数名,所以选择B项。
9.一个函数功能不太复杂,但要求被频繁调用,则应把它定义为()
A.内联函数
B.重载函数
C.递归函数
D.嵌套函数
答案:
A
解析:
(P59)内联函数特征代码少,频繁调用,执行效率高。
重载函数解决统一接口的问题;递归是子程序调用,程序调用要耗费很多空间和时间,循环/迭代都比递归有效率得多,递归只是从形式上,逻辑比较简洁。
嵌套函数即反复调用,速度较慢。
所以选择A项。
10.下面函数模板定义中不正确的是()
A.A
B.B
C.C
D.D
答案:
A
解析:
(P147)A项中F是一个返回Q类型的值,而return中用返回类型作为返回值错误。
所以选择A项。
11.假设ClassY:
publicX,即类Y是类X的派生类,则说明一个Y类的对象时和删除Y类对象时
,调用构造函数和析构函数的次序分别为()
A.X,Y;Y,X
B.X,Y;X,Y
C.Y,X;X,Y
D.Y,X;Y,X
答案:
A
解析:
(P130)派生类构造函数必须对这三类成员进行初始化,其执行顺序:
调用基类构造函数;调用子对象的构造函数;派生类的构造函数体。
析构函数在执行过程中也要对基类和成员对象
进行操作,但它的执行过程与构造函数正好相反,即对派生类新增普通成员进行清理;调用成员对象析构函数,对派生类新增的成员对象进行清理;调用基类析构函数,对基类进行清理,所以选择A项。
12.适宜采用inline定义函数情况是()
A.函数体含有循环语句
B.函数体含有递归语句
C.函数代码少、频繁调用
D.函数代码多、不常调用
答案:
C
解析:
(P59)内联函数具有程序代码少、频繁调用和执行效率高的特征,所以选择C项。
13.假定一个类的构造函数为A(intaa,intbb){a=aa--;b=a*bb;},则执行Ax(4,5);语句后
,x.a和x.b的值分别为()
A.3和15
B.5和4
C.4和20
D.20和5
答案:
C
解析:
(P75)a=4,因为后减,b的值与a、bb相关,b=4*5=20,而与aa没有任何关系。
14.在类中说明的成员可以使用关键字的是()
A.public
B.extern
C.cpu
D.register
答案:
A
解析:
extern用于声明外部变量的。
register声明寄存器类型变量。
无cpu类型。
它们都不能声明类成员。
public声明为公有访问权限,所以选择A项。
15.下列不能作为类的成员的是()
A.自身类对象的指针
B.自身类对象
C.自身类对象的引用
D.另一个类的对象
答案:
B
解析:
类的定义,如果有自身类对象,使得循环定义,B项错误。
在类中具有自身类的指针,可以实现链表的操作,当然也可以使用对象的引用。
类中可以有另一个类的对象,即成员对象。
所以选择B选项。
16.使用地址作为实参传给形参,下列说法正确的是()
A.实参是形参的备份
B.实参与形参无联系
C.形参是实参的备份
D.实参与形参是同一对象
答案:
D
解析:
(P51)地址作为实参,表示实参与形参代表同一个对象。
如果实参是数值,形参也是普通变量,此时形参是实参的备份。
所以选择D项。
17.下列程序的输出结果是()
#include
voidmain()
{intn[][3]={10,20,30,40,50,60};
int(*p)[3];
p=n;
cout<
A.10,30,50
B.10,20,30
C.20,40,60
D.10,30,60
答案:
B
解析:
如果数组元素都是相同类型的指针,则称这个数组为指针数组。
指针数组一般用于处理二维数组。
声明的格式为:
<数据类型><(*变量名)><[元素个数]>。
p表示指向数组n的行指针。
如果将指针的初始化(*p)[3]=b;地址的等价形式:
p+ip[i]*(p+i)都表示b数组第i+1行的第1个元素的首地址。
*(p+i)+jp[i]+j&p[i][j]都表示b数组第i+1行、第j+1列元素的地址。
值的等价形式:
*(*(p+i)+j)*(p[i]+j)p[i][j]都表示b数组第i+1、第j+1列元素的值。
所以题目分别访问p[0][0],p[0][1],p[0][2]。
18.在C++中,使用流进行输入输出,其中用于屏幕输入()
A.cin
B.cerr
C.cout
D.clog
答案:
A
解析:
(P193)
(1)标准输入流cin:
istream类的对象。
(2)标准输出流cout:
ostream类的对象。
(3)非缓冲型标准出错流cerr:
ostream类的对象。
(4)缓冲型标准出错流clog:
ostream类的对象
19.假定AA为一个类,a()为该类公有的函数成员,x为该类的一个对象,则访问x对象中函数
成员a()的格式为()
A.x.a
B.x.a()
C.x->a
D.(*x).a()
答案:
B
解析:
(P41)对象访问成员的方式为:
对象名.成员。
指针可以有两种:
(*对象指针).成员或者对象指针->成员。
A选项是访问数据成员,B项是访问成员函数。
20.关于对象概念的描述中,说法错误的是()
A.对象就是C语言中的结构变量
B.对象代表着正在创建的系统中的一个实体
C.对象是类的一个变量
D.对象之间的信息传递是通过消息进行的
答案:
A
解析:
(P37)A对象在C++中才有,包括数据和操作两项,而C中的变量只有数据,没有操作。
所以A项错误。
二、填空题
1.C++的流库预定义了4个流,它们是cin、cout、clog和___。
答案:
(P193)cerr
[解析]cin、cout、clog和cerr分别用于标准输入、输出、标准错误流(缓冲)和标准错误流(非缓冲)。
2.每个对象都是所属类的一个___。
答案:
(P69)实例
[解析]类是对象的抽象,对象是类的一个实例。
3.在已经定义了整型指针ip后,为了得到一个包括10个整数的数组并由ip所指向,应使用语
句___。
答案:
(P78)int*ip=newint[10];
[解析]new用来动态开辟空间。
常用来产生动态数组及对象构造函数。
4.函数模板中紧随template之后尖括号内的类型参数都要冠以保留字___。
答案:
(P145)class
[解析]类模板的使用。
template,也可以引入多参数的如:
templateT1,classT2,...,classTn>
5.定义类的动态对象数组时,系统只能够自动调用该类的___构造函数对其进行初始化。
答案:
(P80)无参
[解析]使用new创建对象数组,调用无参构造函数。
6.表达式cout<答案:
‘\n’
[解析]endl与字符常量‘\n’等价。
7.在C++中,访问一个指针所指向的对象的成员所用的指向运算符是___。
答案:
->
[解析]指针使用成员有两种方法:
“->”指向运算符和“.”成员访问运算符。
8.假如一个类的名称为MyClass,使用这个类的一个对象初始化该类的另一个对象时,可以调
用___构造函数来完成此功能。
答案:
(P80)复制或拷贝
复制或拷贝构造函数就是用对象初始化新的对象。
9.对赋值运算符进行重载时,应声明为___函数。
答案:
(P183)类成员
[解析]运算符重载的方法有友元或者成员函数两种途径,但是赋值运算符只能使用成员函数的方法来实现。
10.如果要把A类成员函数f()且返回值为void声明为类B的友元函数,则应在类B的定义中加入的语句___。
答案:
(P109)friendvoidA:
:
f();
[解析]成员函数作为另一个类的友元函数,格式为:
friend返回类型类名:
:
函数(形参)。
11.下列程序段的输出结果是___。
for(i=0,j=10,k=0;i<=j;i++,j-=3,k=i+j);cout<答案:
4
[解析]for循环结构,三个表达式的作用,初始化、循环判断条件和循环变量变化。
循环执行了三次,k的作用是计算i、j的和。
12.String类的___方法返回查找到的字符串在主串的位置。
答案:
(P40)find
[解析]string类对象方法的find,查不到字符串,则返回-1。
13.intn=0;
while(n=1)n++;
while循环执行次数是___。
答案:
无限次
[解析]=是赋值运算符,不是关系运算符,且不等0,所以死循环。
14.控制格式输入输出的操作中,函数___是用来设置填充字符。
要求给出函数名和参数类型
答案:
(P195)setfill(char)
[解析]格式控制方法的使用,如setw,setfill等等。
15.C++语言支持的两种多态性分别是编译时的多态性和___的多态性。
答案:
(P167)运行时
[解析]多态性包括静态的(编译时)多态性和动态的(运行时)多态性。
16.设函数sum是由函数模板实现的,并且sum(3,6)和sum(4.6,8)都是正确的函数调用,则函数模板具有___个类型参数。
答案:
(P61)2
17.执行下列代码
stringstr("HelloC++");
cout<程序的输出结果是___。
答案:
(P42)C++
[解析]substr取子字符串,第1个参数表示要截取子串在字符串中的位置,第2个表示取多少个字符。
18.在面向对象的程序设计中,将一组对象的共同特性抽象出来形成___。
答案:
(P38)类
[解析]类是相似特征的对象的抽象,对象是类的一个实例。
19.定义类动态对象数组时,元素只能靠自动调用该类的___来进行初始化。
答案:
(P77)无参构造函数
[解析]使用new创建动态对象数组,不能有参数,所以只能调用无参的构造函数,初始化对象
20.已知有20个元素int类型向量V1,若用V1初始化为V2向量,语句是___。
答案:
(P151)ectorV2(V1);
[解析]采用向量初始化另一个向量的形式:
vectorname1(name);
一、单项选择题
1.静态成员函数没有()
A.返回值
B.this指针
C.指针参数
D.返回类型
答案:
B
解析:
(P107)静态成员函数是普通的函数前加入static,它具有函数的所有的特征:
返回类型、形参,所以使用(P107)静态成员函数,指针可以作为形参,也具有返回值。
静态成员是类具有的属性,不是对象的特征,而this表示的是隐藏的对象的指针,因此静态成员函数没有this指针。
静态成员函数当在类外定义时,要注意不能使用static关键字作为前缀。
由于静态成员函数在类中只有一个拷贝(副本),因此它访问对象的成员时要受到一些限制:
静态成员函数可以直接
访问类中说明的静态成员,但不能直接访问类中说明的非静态成员;若要访问非静态成员时,必须通过参数传递的方式得到相应的对象,再通过对象来访问。
2.假定AB为一个类,则执行“ABa
(2),b[3],*p[4];”语句时调用该类构造函数的次数
为()
A.3
B.4
C.5
D.9
答案:
B
解析:
(P79)a
(2)调用1次带参数的构造函数,b[3]调用3次无参数的构造函数,指针没有给它分配空间,没有调用构造函数。
所以共调用构造函数的次数为4。
3.有关多态性说法不正确的是()
A.C++语言的多态性分为编译时的多态性和运行时的多态性
B.编译时的多态性可通过函数重载实现
C.运行时的多态性可通过模板和虚函数实现
D.实现运行时多态性的机制称为动态多态性
答案:
C
解析:
(P171)多态性分为静态的和动态的。
静态通过函数的重载来实现,动态是通过基类指针或基类引用和虚函数来实现的。
所以错误的是C项。
4.假定一个类的构造函数为“A(inti=4,intj=0){a=i;b=j;}”,则执行“Ax
(1);”语
句后,x.a和x.b的值分别为()
A.1和0
B.1和4
C.4和0
D.4和1
答案:
A
解析:
(P75)带默认的构造函数,对应实参没有值时就采用形参值。
调用构造函数时,i=1,不采用默认值,而只有一个参数,j采用默认值0即j=0,因此a=1,b=0,选择A项。
5.类MyA的拷贝初始化构造函数是()
A.MyA()
B.MyA(MyA*)
C.MyA(MyA&)
D.MyA(MyA)
答案:
C
解析:
(P80)复制即拷贝构造函数使用对象的引用作形参,防止临时产生一个对象,A无参构造函数,B是指针作为形参,D项是对象,所以选择C项。
6.在C++中,函数原型不能标识()
A.函数的返回类型
B.函数参数的个数
C.函数参数类型
D.函数的功能
答案:
D
解析:
函数的声明,说明函数的参数、返回类型以及函数名,函数体即实现部分决定功能。
所以函数的原型不能决定函数的功能。
7.友元关系不能()
A.提高程序的运行效率
B.是类与类的关系
C.是一个类的成员函数与另一个类的关系
D.继承
答案:
D
解析:
(P111)友元可以是函数与类的关系即友元函数,也可以类与类的关系即友元类,但友元不能继承,是单向性,且不具有传递性。
友元可以访问类中所有成员,提高了访问的方便性。
因此选择D项。
8.实现两个相同类型数加法的函数模板的声明是()
A.add(Tx,Ty)
B.Tadd(x,y)
C.Tadd(Tx,y)
D.Tadd(Tx,Ty)
答案:
D
解析:
(P63)实现两个相同类型数加法结果应该和操作数具有相同类型。
进行加法运算后结果也是和参数具有相同类型,需要返回值。
A无返回值时要用void,B形参无类型,C形参y没有类型,所以选择D项。
9.在inta=3,int*p=&a;中,*p的值是()
A.变量a的地址值
B.无意义
C.变量p的地址值
D.3
答案:
D
解析:
*p代表引用a变量的值,p代表a的地址值。
所以选择D项。
10.下列不是描述类的成员函数的是()
A.构造函数
B.析构函数
C.友元函数
D.拷贝构造函数
答案:
C
解析:
(P109)构造函数、析构函数、拷贝构造函数都是特殊的成员函数,友元则不是成员函数。
所以选择C项。
11.如果从原有类定义新类可以实现的是()
A.信息隐藏
B.数据封装
C.继承机制
D.数据抽象
答案:
C
解析:
(P129)继承指在原有类的基础上产生新类。
数据封装即数据和操作组合在一起,形成类。
信息的隐藏,通过访问权限来实现。
数据抽象,将事物的特征抽象为数据成员或服务。
因此选择C项。
12.下面有关类说法不正确的是()
A.一个类可以有多个构造函数
B.一个类只有一个析构函数
C.析构函数需要指定参数
D.在一个类中可以说明具有类类型的数据成员
答案:
C
解析:
(P80)构造函数可以有参数、可以重载、因此可以有多个,A项正确。
析构函数只有一个不能重载、不能继承,没有返回值,B项正确,C项错误。
13.在函数定义中的形参属于()
A.全局变量
B.局部变量
C.静态变量
D.寄存器变量
答案:
B
解析:
形参或函数中定义的变量都是局部变量。
在函数外定义的变量是全局变量。
形参只能用局部变量,频繁使用的变量可以声明为寄存器变量,形参不能使用静态变量或寄存器变量。
14.下列有关重载函数的说法中正确的是()
A.重载函数必须具有不同的返回值类型
B.重载函数参数个数必须相同
C.重载函数必须有不同的形参列表
D.重载函数名可以不同
答案:
C
解析:
(P59)函数的重载必须函数名相同而形参类型或个数不同,与返回值无关。
15.this指针存在的目的是()
A.保证基类私有成员在子类中可以被访问
B.保证基类保护成员在子类中可以被访问
C.保证每个对象拥有自己的数据成员,但共享处理这些数据成员的代码
D.保证基类公有成员在子类中可以被访问
答案:
C
解析:
(P86)C++要求函数在被调用之前,应当让编译器知道该函数的原型,以便编译器利用函数原型提供的信息去检查调用的合法性,强制参数转换成为适当类型,保证参数的正确传递。
对于标准库函数,其声明在头文件中,可以用#include宏命令包含这些原型文件;对于用户自定义函数,先定义、后调用的函数可以不用声明,但后定义、先调用的函数必须声明。
一般为增加程序的可理解性,常将主函数放在程序开头,这样需要在主函数前对其所调用的函数一一进行声明,以消除函数所在位置的影响。
所以选择C项。
16.关于new运算符的下列描述中,错误的是()
A.它可以用来动态创建对象和对象数组
B.使用它创建的对象或对象数组可以使用运算符delete删除
C.使用它创建对象时要调用构造函数
D.使用它创建对象数组时必须指定初始值
答案:
D
解析:
(P78)new创建的对象数组不能指定初始值,所以调用无参的构造函数,选择D项。
17.已知:
p是一个指向类A数据成员m的指针,A1是类A的一个对象。
如果要给m赋值为5,正确的是()
A.A1.p=5;
B.A1->p=5;
C.A1.*p=5;
D.*A1.p=5;
答案:
C
解析:
(P118)A中p是指针即地址,错误;B选项中A1不是指针不能使用指向运算符->,错误
;“*”比“.”级别要高,所以D选项*A1.p=5相当于(*A1).p=5;错误。
另外涉及到指向成员函数
时注意以下几点:
指向成员函数的指针必须于其赋值的函数类型匹配的三个方面:
(1)参数类型和个数;
(2)返回
类型;(3)它所属的类类型。
成员函数指针的声明:
指向short型的Screen类的成员的指针定义如下:
shortScreen:
:
*ps_Screen;
ps_Screen可以用_height的地址初始化如下:
shortScreen:
:
*ps_Screen=&Screen:
:
_height;
类成员的指针必须总是通过特定的对象或指向改类型的对象的指针来访问。
是通过使用两个指
向成员操作符的指针(针对类对象和引用的.*,以及针对指向类对象的指针的->*)。
18.以下基类中的成员函数表示纯虚函数的是()
A.virtualvoidtt()=0
B.voidtt(int)=0
C.virtualvoidtt(int)
D.virtualvoidtt(int){}
答案:
A
解析:
(P173)当在基类中不能为虚函数给出一个有意义的实现时,可以将其声明为纯虚函数,实现由派生类完成。
格式:
virtual<函数返回类型说明符><函数名>(<参数表>)=0;。
19.C++类体系中,不能被派生类继承的有()
A.常成员函数
B.构造函数
C.虚函数
D.静态成员函数
答案:
B
解析:
(P132)构造函数不能被继承。
20.静态成员函数不能说明为()
A.整型函数
B.浮点函数
C.虚函数
D.字符型函数
答案:
C
解析:
(P108)使用关键字static声明的成员函数就是静态成员函数,静态成员函数也属于