《C++语言程序》测试题及答案.docx

上传人:b****6 文档编号:4770595 上传时间:2022-12-08 格式:DOCX 页数:51 大小:41.30KB
下载 相关 举报
《C++语言程序》测试题及答案.docx_第1页
第1页 / 共51页
《C++语言程序》测试题及答案.docx_第2页
第2页 / 共51页
《C++语言程序》测试题及答案.docx_第3页
第3页 / 共51页
《C++语言程序》测试题及答案.docx_第4页
第4页 / 共51页
《C++语言程序》测试题及答案.docx_第5页
第5页 / 共51页
点击查看更多>>
下载资源
资源描述

《C++语言程序》测试题及答案.docx

《《C++语言程序》测试题及答案.docx》由会员分享,可在线阅读,更多相关《《C++语言程序》测试题及答案.docx(51页珍藏版)》请在冰豆网上搜索。

《C++语言程序》测试题及答案.docx

《C++语言程序》测试题及答案

《c++程序设计》(本科)

一、判断题(错误的在后面写“F”,正确的写“T”,每题1分)

1.程序是描述算法的编程工具。

T

2.将函数模板与某个具体数据类型连用,就产生了模板函数,称这个过程为函数模板实例化。

T

3.C++语言中,用来为对象初始化的特殊成员函数称为构造函数;用于在对象撤销时执行一些清理任务的特殊成员函数称为析构函数。

T

4.逐条翻译并执行的翻译程序称为编译程序。

F

5.把所有类组织在一个树形结构中,这时所有类,不管它们之间的差别有多大,都有一个共同的相关类,这种结构被称为类树。

类群是由一些彼此密切相关的类和类族组成的。

F

6.如果在定义一个类时,该类继承了多个基类的特征,那么这个继承关系称为多重继承。

T

7.不同对象可以调用相同名称的函数,并可导致完全相同的行为的现象称为多态性。

F

8.形式参数表是用括号分隔的变量说明列表,变量称为函数的形式参数,有时也简称为形参。

F

9..在C++语言中,只要在声明函数原型时形式参数的个数或者对应的类型不同,两个或更多的函数就可以共用同一个名字。

这种在同一作用域中允许多个函数使用同一函数名的措施被称为重载。

T

8.C++的作用域分辨:

可以迫使编译器“看到”当前作用域的外层部分,存取那些被隐藏的名字。

这是由作用域分辨操作符实现的,这一过程叫做作用域分辨。

T

11. 说明函数原型时不需要指明每个函数参数的名字,只需要说明每个参数的类型和返回值类型就可以了。

T

12. 所有的表达式都有值。

F

13. 程序的编译是以文件为单位的,因此将程序分到多个文件中可以减少每次对程序修改所带来的编译工作量。

T

14. 类的静态数据成员需要在定义每个类的对象时进行初始化。

F

15. 基类中被说明为protected和private的成员只能被其派生类的成员函数访问,不能被其它的函数访问。

F

16. 当将一个类S定义为另一个类A的友元类时,类S的所有成员函数都可以直接访问类A的所有成员。

T

17. 当函数的返回值是数组类型的,传递的是数组第一个元素的地址。

F

18. 如果派生类的成员函数的原型与基类中被定义为虚函数的成员函数原型相同,那么,这个函数自动继承基类中虚函数的特性。

T

19. 字符串’hello,world”在内存中存放时,占用11个字节的空间。

F

20.用new动态申请的内存空间,必须用delete来释放。

T

21、变量必须先定义或说明,后使用。

T

23、常量不能作为左值使用。

T

23、头文件中一般存放着变量和常量的定义、函数的原型以及类的定义。

F

24、类的友元函数可以直接访问该类的所有成员。

T

25、派生类的成员函数可以直接访问基类的所有成员。

F

26、一个类可以作为另一个类的友元类。

T

27、函数的参数和返回值类型可以是简单数据类型,也可以是指什、引用、数组和类。

F

28、在基类中被说明为虚函数的类的成员函数必须在每个派生类中说明为虚函数,才能具有多态的特征。

F

29、下面两个语句是等价的:

F

   charstr[]="hello,world";

 charstr[11]="hello,world";

30、用new动态申请的内存是在堆中分配的,而不是在栈中分配的。

T

31.静态联编所支持的多态性称为编译时的多态性。

T

32.如果一个类中至少有一个实函数,则称这个类为抽象类。

F

33.用于在对象消失时执行一些清理任务的函数叫虚函数。

F

34.C++源程序文件的缺省扩展名为cppT

35.由C++源程序文件编译而成的目标文件的缺省扩展名为likF

36.由C++目标文件连接而成的可执行文件的缺省扩展名为objF

37.编写C++程序一般需经过的几个步骤依次是编辑、编译、连接、调试T

38.标识符defaultthenwhile全是保留字F

39.能作为C++程序的基本单位是语句T

40.程序中主函数的名字为任意标识符F

二、填空题(每题3分)

1.假定x=5,y=6,则执行表达式y+=x--计算后,x和y的值分别为_____4_____和___11_______。

2.C++常数0x145对应的十进制值为____325______。

3.C++常数0345对应的十进制值为____229______。

4.十进制常数245对应的十六进制的C++表示为____0xF5(F大小写均可)_____

5.十进制常数245对应的八进制的C++表示为___0365(F大小写均可)_______。

6.signedchar类型的值域范围是_-128_______至_____+127_____之间的整数。

7.int和float类型的数据分别占用___4______和______4____个字节。

8.float和double类型的数据分别占用_____4____和__8______个字节。

9.bool和char类型的数据分别占用____1_____和_____1___个字节。

10.unsignedshortint和int类型的长度分别为___2______和____4____。

11.字符串“This\’sabook.\n”的长度为___15_______。

12.字符串“\nThis\’sapen\n\n”的长度为_____15_____。

13.在C++中存储字符串“abcdef”至少需要___7_____个字节。

14.在C++中存储字符串“a+b=c”至少需要__6______个字节。

14.假定x和y为整型,其值分别为16和5,则x%y和x/y的值分别为_____1_____和______3____。

15.若while循环的“头”为”while(i++<=10)”,并且i的初值为0,同时在循环体中不会修改i的值,则循环体将被重复执行__11____次后正常结束。

17.若do循环的“尾”为”while(++i<10)”,并且i的初值为0,同时在循环体中不会修改i的值,则循环体将被重复执行____10__次后正常结束。

18.当在程序中执行到__break______语句时,将结束本层循环类语句或switch语句的执行。

19.当在程序中执行到____continue____语句时,将结束所在循环语句中循环体的一次执行。

20.在程序中执行到____return____语句时,将结束所在函数的执行过程,返回到调用该函数的位置。

21.在程序执行完__主(或main)_____函数调用后,将结束整个程序的执行过程,返回到C++集成开发窗口。

22.元素类型为int的数组a[10]共占用___40_____字节的存储空间。

23.元素类型为double的二维数组a[4][6]共占用___192_____字节的存储空间。

24.元素类型为char的二维数组a[10][30]共占用___300_____字节的存储空间。

25.存储字符’a’和字符串”a”分别需要占用____1____和_____2___个字节。

26.空串的长度为___0_____,存储它需要占用___1_____个字节。

27.字符串”\’a\’xy=4\n”的长度为__7______。

28.字符串”a:

\\xxk\\数据”的长度为__11__。

29.用于存储一个长度为n的字符串的字符数组的长度至少为___n+1_____。

30.若a是一个字符数组,则从键盘上向该数组输入一个字符串的表达式为_cin>>a___。

31.C++是将源程序_一次翻译成目标程序_____,然后再执行,这种翻译程序称为编译程序。

32.联合的若干数据成员使用地址___同一___,占据的内存是联合中占内存最大的数据成员所占用的内存。

33.作用域分辨操作符的一般形式为类名:

:

类标识符,作用域分辨不仅可用于类中,而且可以用在____函数调用__时。

34.将关键词const写在___函数头___之后,__函数体____,之前,说明该函数是一个const成员函数。

35.C++是在___标准C语言___的基础上,引入面向对象概念而扩充形成的混合型面向对象语言。

36.在动态联编中,直到_程序运行_____时才能确定调用哪个函数。

静态联编是在程序编译时进行的。

37.类型转换函数___不能___带有参数,当被派生类继承并被说明为___虚函数___时,可以定义多个转换函数。

38.继承是___对象___的一个特点,继承支持___层次___类概念

39.C++的__作用域____规则能保证编译器调用正确的成员函数。

40.在C++中,声明构造函数和析构函数时,_不能_____使用const或volatile关键词。

41.只能用类运算符来重载的运算符是:

_=_____,___()___,__[]____,___->___。

42.应该养成将所有extern说明放到__头文件____中去的习惯,对于自己编写的函数,必须自己给出__函数类型____说明。

43.结构是___类___,的一种特例,其中成员在缺省情况下是_公有的_____。

44.当使用delete删除一个对象时,delete隐含着对__析构函数____函数的一次调用,如果这个函数为虚函数,则这个调用采用___动态___联编。

45.const放在函数前面使常量成员返回__常量对象____。

如果定义一个const对象,则只能访问该对象的const成员函数。

46.在面向对象的程序设计中,一切都是围绕着___类___展开的。

47.析构造函数是和___类___同名的函数。

48.指向基类的对象的指针变量也可以指向___派生类______的对象。

49.若多继承时,多个基类中拥有一个同名的成员,则__不能_______用调整访问权限确定对该成员的访问

50.多继承情况下,派生类的构造函数的执行顺序取决于__继承_______派生类时所指定的各基类的顺序。

51.构造函数___不能__被继承,析构函数______不能______被继承。

52.___多___继承情况下,派生类中对基类成员的访问会出现二义性。

解决二义性的方法是______成员名限定法______、___支配规则__和__虚基类___

53.垂直访问时,保护成员的访问控制权限与______公有___成员相同。

54.派生类可以调用其____基类_____中不具备的数据和操作。

55.利用继承能够实现___软件复用______。

这种实现缩短了程序的开发时间,促使开发人员复用已经测试和调试好的高质量软件。

56.当撤消一个含有基类和子对象成员的派生类对象时,将首先完成___派生类___的析构函数定义体的执行,接着完成______子对象成员______的析构函数定义体的执行,最后完成___基类___的析构函数定义体的执行。

57.如果类Alpha继承了类Beta,则类Alpha称为___派生___类,类Beta称为__基___类

58.对基类数据成员的初始化必须在派生类构造函数中的____成员初始化列表_____处执行。

59.在派生类中使用基类的成员,可以显示地使用__成员名限定符_______来使用基类成员

60.当将基类指针转换为派生类指针时,由于编译器认为这种操作是危险的,所以必须要使用____强制类型转换_____。

61.多继承可以视为是___单继承___的扩展,派生类及其基类可用一个___有向无环图DAG___表示。

62.继承是___对象___的一个特点,继承支持___层次___类概念。

63.若需要定义一个标识符常量,并且使C++能够进行类型检查,则应在定义语句的开始使用保留字const.

64.逻辑表达式x>3&&x<10的相反表达式为x<=3||x>=10.

65.逻辑表达式a>b||b==5的相反表达式为a<=b&&b!

=5.

66.假定一个二维数组的定义为”chara[5][6];”,则该数组所含元素的个数为30,所占存储空间的字节数为30.

67.变量分为全局和局部两种,全局变量没有赋初值时,将由系统自动置为0.

68.假定a是一个一维数组,则a[i]对应的存储地址(以字节为单位)为a+i*sizeof(a[i])

69.假定一个结构类型的定义为”structA{inta,b;A*c;};”,则该类型的大小为12字节.

70.假定要访问一个结构指针p所指对象中的b指针成员所指的对象,则表示方法为*(p->b).

三、单选题(每题2分,在下列各题的备选答案中,选出一个正确答案,并将其号码填写在题目后面的括号内。

A1.C++源程序文件的缺省扩展名为()。

A.cppB.exeC.objD.lik

C2.由C++源程序文件编译而成的目标文件的缺省扩展名为()。

A.cppB.exeC.objD.lik

B3.由C++目标文件连接而成的可执行文件的缺省扩展名为()。

A.cppB.exeC.objD.lik

B4.编写C++程序一般需经过的几个步骤依次是()。

A.编译、编辑、连接、调试B.编辑、编译、连接、调试

C.编译、调试、编辑、连接D.编辑、调试、编辑、连接

B5.以下标识符中不全是保留字的是()。

A.caseforintB.defaultthenwhile

C.boolclasslongD.gotoreturnchar

C6.能作为C++程序的基本单位是()。

A.字符B.语句C.函数D.源程序文件

A7.程序中主函数的名字为()。

A.mainB.MAINC.MainD.任意标识符

D8.C++程序的基本模块为()。

A.表达式B.标识符C.语句D.函数

B9.可用作C++语言用户标识符的一组标识符是()。

A.voiddefine+WORDB.a3_b3_123YN

C.for-abcCaseD.2aDOsizeof

D10.存储以下数据,占用存储字节最多的是()。

A.0B.‘0’C.“0”D.0.0

D11.程序运行中需要从键盘上输入多于一个数据时,各数据之间应使用()符号作为分隔符。

A.空格或逗号B.逗号或回车C.逗号或分号D.空格或回车

C12.设”inta=12;”,则执行完语句”a+=a*a;”后,a的值是()。

A.12B.144C.156D.288

D13.假设在程序中a、b、c均被定义成整型,所赋的值都大于1,则下列能正确表示代数式

的表达式是()。

A.1.0/a*b*cB.1/(a*b*c)C.1/a/b/(float)cD.1.0/a/b/c

D14.设”inta=15,b=26;”,则”cout<<(a,b);”的输出结果是()。

A.15B.26,15C.15,26D.26

C15.设x是一个bool型的逻辑量,y的值为10,则表达式x&&y的值为()。

A.1B.0C.与x值相同D.与x值相反

A16.x>0&&x<=10的相反表达式为()。

A.x<=0||x>10B.x<=0&&x>10C.x<=0||x<=10D.x>0&&x>10

B17.x>0||y==5的相反表达式为()。

A.x<=0||y!

=5B.x<=0&&y!

=5C.x>0||y!

=5D.x>0&&y==5

A18.设x和y均为bool量,则x&&y为真的条件是()。

A.它们均为真B.其中一个为真C.它们均为假D.其中一个为假

C19.设x和y均为bool量,则x||y为假的条件是()。

A.它们均为真B.其中一个为真C.它们均为假D.其中一个为假

B20.字符串”a+b=12\n”的长度为()。

A.6B.7C.8D.9

B21.假定下列x和y均为int型变量,则不正确的赋值为()。

A.x+=y++B.x++=y++C.x=++yD.++x=++y

C22.下列的符号常量定义中,错误的定义是()。

A.constM=10;B.constintM=20;C.constcharch;D.constboolmark=true;

C23.循环语句“for(inti=0;i

A.1B.n-1C.nD.n+1

B24.在下面循环语句中循环体执行的次数为()。

for(inti=0;i

if(i>n/2)break;

A.n/2B.n/2+1C.n/2-1D.n-1

D25.在下面循环语句中内层循环体S语句的执行总次数为()。

for(inti=0;i

for(intj=i;j

A.n2B.(n+1)/2C.n(n-1)/2D.n(n+1)/2

C26.在下面循环语句中循环体执行的次数为()。

inti=0,s=0;while(s<20){i++;s+=i;}

A.4B.5C.6D.7

A27.在下面循环语句中循环体执行的次数为()。

inti=0;doi++;while(i*i<10);

A.4B.3C.5D.2

A28.当处理特定问题时的循环次数已知时,通常采用()来解决。

A.for循环B.while循环C.do循环D.switch语句

C29.循环体至少被执行一次的语句为()。

A.for循环B.while循环C.do循环D.任一种循环

B30.switch语句能够改写为()语句。

A.forB.ifC.doD.while

D31.do语句能够改写为()语句。

A.复合B.ifC.switchD.while

C32.在下面的一维数组定义中,哪一个有语法错误。

()

A.inta[]={1,2,3};B.inta[10]={0};C.inta[];D.inta[5];

D33.在下面的字符数组定义中,哪一个有语法错误。

()。

A.chara[20]=”abcdefg”;B.chara[]=”x+y=55.”;

C.chara[15];D.chara[10]=’5’;

C34.在下面的二维数组定义中,正确的是()。

A.inta[5][];B.inta[][5];C.inta[][3]={{1,3,5},{2}};D.inta[](10);

C35.假定一个二维数组的定义语句为“inta[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为()。

A.2B.4C.6D.8

A36.假定一个二维数组的定义语句为“inta[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为()。

A.0B.4C.8D.6

B37.若定义了函数double*function(),则函数function的返回值为()。

A.实数型B.实数的地址C.指向函数的指针D.函数的地址

B38.以下说法中正确的是()。

A.C++程序总是从第一个定义的函数开始执行B.C++程序总是从main函数开始执行

C.C++函数必须有返回值,否则不能使用函数

D.C++程序中有调用关系的所有函数必须放在同一个程序文件中

C39.以下叙述中不正确的是()。

A.在一个函数中,可以有多条return语句B.函数的定义不能嵌套,但函数的调用可以嵌套

C.函数必须有返回值D.不同的函数中可以使用相同名字的变量

A40.函数重载是指()。

A.两个或两个以上的函数取相同的函数名,但形参的个数或类型不同

B.两个以上的函数取相同的名字和具有相同的参数个数,但形参的类型可以不同

C.两个以上的函数名字不同,但形参的个数或类型相同

D.两个以上的函数取相同的函数名,并且函数的返回类型相同

C41.以下关于函数模板叙述正确的是()。

A.函数模板也是一个具体类型的函数

B.函数模板的类型参数与函数的参数是同一个概念

C.通过使用不同的类型参数,函数模板可以生成不同类型的函数

D.用函数模板定义的函数没有类型

C42.下列()的调用方式是引用调用。

A.形参和实参都是变量B.形参是指针,实参是地址值

C.形参是引用,实参是变量D.形参是变量,实参是地址值

A43.为了提高程序的运行速度,可将不太复杂的功能用函数实现,此函数应选择()。

A.内联函数B.重载函数C.递归函数D.函数模板

B44.函数原型语句正确的是()。

A.intFunction(voida);B.voidFunction(int);

C.intFunction(a);D.voidint(doublea);

B45.C++中函数返回值的类型是由()决定的。

A.return语句中表达式的类型B.该函数定义时的类型

C.调用函数时的调用语句D.系统根据结果

A46.以下函数的返回结果是()。

intfunction(char*x){

char*p=x;while(*p++);return(p-x-1);

}

A.求字符串的长度B.将字符串x连接到字符串p后面

C.将字符串x复制到字符串p中D.将字符串x反向存放

B47.函数调用func((exp1,exp2),(exp3,exp4,exp5))中所含实参的个数为()个。

A.1B.2C.4D.5

B48.设有如下函数定义

intf(char*s){

char*p=s;

while(*p!

=’\0’)p++;

return(p-s);

}

在主函数中用cout<

A.3B.4C.5D.6

C49.以下正确的函数原型语句是()。

A.doublefun(intx,inty)B.doublefun(intx;inty)

C.doublefun(int,int);D.doublefun(intx,y);

B

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

当前位置:首页 > 高中教育 > 高考

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1