《C++语言程序》测试题及答案要点_第1页
《C++语言程序》测试题及答案要点_第2页
《C++语言程序》测试题及答案要点_第3页
《C++语言程序》测试题及答案要点_第4页
《C++语言程序》测试题及答案要点_第5页
已阅读5页,还剩29页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、C+程序设计(本科)一、判断题(错误的在后面写“ F” ,正确的写“T” , 每题 1 分)1. 程序是描述算法的编程工具。 T2. 将函数模板与某个具体数据类型连用,就产生了模板函数,称这个过程为函数模板实例化。T3. C+语言中,用来为对象初始化的特殊成员函数称为构造函数;用于在对象撤销时执行一些清理任务的特殊成员函数称为析构函数。 T4. 逐条翻译并执行的翻译程序称为编译程序。 F5. 把所有类组织在一个树形结构中,这时所有类,不管它们之间的差别有多大,都有一个共同的相关类, 这种结构被称为类树。 类群是由一些彼此密切相关的类和类族组成的。 F6. 如果在定义一个类时,该类继承了多个基类

2、的特征,那么这个继承关系称为多重继承。T7. 不同对象可以调用相同名称的函数,并可导致完全相同的行为的现象称为多态性。F8. 形式参数表是用括号分隔的变量说明列表,变量称为函数的形式参数,有时也简称为形参。F8.1. C+语言中,只要在声明函数原型时形式参数的个数或者对应的类型不同,两个或更多的函数就可以共用同一个名字。这种在同一作用域中允许多个函数使用同一函数名的措施被称为重载。 T8. C+的作用域分辨:可以迫使编译器“看到”当前作用域的外层部分,存取那些被隐藏的名字。这是由作用域分辨操作符实现的,这一过程叫做作用域分辨。T11 说明函数原型时不需要指明每个函数参数的名字,只需要说明每个参

3、数的类型和返回值类型就可以了。 T12 所有的表达式都有值。 F13 程序的编译是以文件为单位的,因此将程序分到多个文件中可以减少每次对程序修改所带来的编译工作量。 T14 类的静态数据成员需要在定义每个类的对象时进行初始化。 F15 基类中被说明为protected和private的成员只能被其派生类的成员函数访问,不能被其它的函数访问。F16 当将一个类S 定义为另一个类A 的友元类时,类S 的所有成员函数都可以直接访问类A 的所有成员。T17 当函数的返回值是数组类型的,传递的是数组第一个元素的地址。 F18 如果派生类的成员函数的原型与基类中被定义为虚函数的成员函数原型相同,那么,这个

4、函数自动继承基类中虚函数的特性。 T19 字符串 ?hello,world 在内存中存放时,占用”11 个字节的空间。 F20.用new动态申请的内存空间,必须用 delete来释放。T21、变量必须先定义或说明,后使用。 T23、常量不能作为左值使用。T23、头文件中一般存放着变量和常量的定义、函数的原型以及类的定义。F24、类的友元函数可以直接访问该类的所有成员。T25、派生类的成员函数可以直接访问基类的所有成员。F26、一个类可以作为另一个类的友元类。T27、函数的参数和返回值类型可以是简单数据类型,也可以是指什、引用、数组和类。F28、在基类中被说明为虚函数的类的成员函数必须在每个派生

5、类中说明为虚函数,才能具有多态的特征。 F29、下面两个语句是等价的:Fchar str ="hello,world"char str11="hello,world"30、用new动态申请的内存是在堆中分配的,而不是在栈中分配的。T31 .静态联编所支持的多态性称为编译时的多态性。T32 .如果一个类中至少有一个实函数,则称这个类为抽象类。F33 .用于在对象消失时执行一些清理任务的函数叫虚函数。F34 . C+ 源程序文件的缺省扩展名为 cppT35 .由C+翎程序文件编译而成的目标文件的缺省扩展名为likF36 .由C+目标文件连接而成的可执行文件的

6、缺省扩展名为objF37 .编写C+和序一般需经过的几个步骤依次是编辑、编译、连接、调试T38 . 标识符 default then while 全是保留字F39 .能作为C+强序的基本单位是语句T40 . 程序中主函数的名字为任意标识符F二、填空题 ( 每题 3分)I .假定x=5, y=6,则执行表达式y+=x-计算后,x和y的值分别为 4和II 。2. C+ 常数 0x145 对应的十进制值为325。3. C+ 常数 0345 对应的十进制值为 229 。4. 十进制常数245对应的十六进制的C+然示为 0xF5 (F大小写均可)5. 十进制常数245对应的八进制的C+求示为0365 (

7、F大小写均可)。6. signed char 类型的值域范围是_-128至+127之间的整数。7. int 和 float 类型的数据分别占用_4和4个字节。8. float 和 double 类型的数据分别占用 4和_ 8个字节。9. bool 和 char 类型的数据分别占用 1和1_个字节。10. unsigned short int 和 int 类型的长度分别为 _2和4。11. 字符串 “ s a book.n ” 的长度为 _15。12. 字符串 “ s a pennn ” 的长度为 15 。13. 在C+用存储字符串abcdef ”至少需要 7 个字节。14. 在C+用存储字符串

8、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

9、.当在程序中执行到 continue 语句时,将结束所在循环语句中循环体的一次执行。20 .在程序中执行到 return 语句时,将结束所在函数的执行过程,返回到调用该函数的位置。21 .在程序执行完_主(或main)函数调用后,将结束整个程序的执行过程,返回到C+集成开发窗口。22 .元素类型为int的数组a10共占用40 字节的存储空间。23 .元素类型为double的二维数组a46共占用192 字节的存储空间。24 .元素类型为char的二维数组a1030共占用300 字节的存储空间。25 .存储字符a'和字符串" a”分别需要占用 1和 2一个字节。26 .空串的长度

10、为0,存储它需要占用1 个字节。27 .字符串” xy=4n ”的长度为_7。28 .字符串“数据”的长度为_11_。29 .用于存储一个长度为n的字符串的字符数组的长度至少为n+1。30 .若a是一个字符数组,则从键盘上向该数组输入一个字符串的表达式为_ cin>>a 。31 . C+是将源程序_一次翻译成目标程序 ,然后再执行,这种翻译程序称为编译程序。32 .联合的若干数据6员使用地址同一,占据的内存是联合中占内存最大的数据成员所占用的内存。33 .作用域分辨操作符的一般形式为类名二类标识符,作用域分辨不仅可用于类中,而且可以用在一函数调用_时。34 .将关键词const写在

11、 函数头 之后,_函数体, 之前,说明该函数是一个const成员函数。35 . C+是在标准C语言的基础上,引入 面向对象概念而扩充形成的混合型面向对象语言。36 .在动态联编中,直到_程序运行 时才能确定调用哪个函数。静态联编是在程序编译 时进行的。37 .类型转换函数不能一带有参数,当被派生类继承并被说明为 虚函数时,可以定义多个转换函数。38 .继承是 对象的一个特点,继承支持一层次一类概念39 . C+的 作用域 规则能保证编译器调用正确的成员函数。40 .在C+中,声明构造函数和析构函数时,_不能使用const或volatile关键词。41 .只能用类运算符来重载的运算符是:_=二,

12、(), 口 ,->。42 .应该养成将所有extern说明放到头文件 中去的习惯,对于自己编写的函数,必须自己给出 _ 函数类型 说明。43 .结构是 一类,的一种特例,其中成员在缺省情况下是_公有的 。44 .当使用delete删除一个对象时,delete隐含着对 析构函数函数的一次调用,如果这个函数为虚函数,则这个调用采用动态联编。45 . const放在函数前面使常量成员返回_常量对象 。如果定义一个 const对象,则只能访问该对象的const成员函数。46 .在面向对象的程序设计中,一切都是围绕着一类展开的。47 .析构造函数是和 类同名的函数。48 .指向基类的对象的指针变量

13、也可以指向_派生类 的对象。49 .若多继承时,多个基类中拥有一个同名的成员,则_不能 用调整访问权限确定对该成员的访问50 .多继承情况下,派生类的构造函数的执行顺序取决于继承 派生类时所指定的各基类的顺序。51 .构造函数_不能_被继承,析构函数 不能 被继承。52 .多继承情况下,派生类中对基类成员的访问会出现二义性。解决二义性的方法是 成员名限定法支配规则_和_虚基类53 .垂直访问时,保护成员的访问控制权限与 公有成员相同。54 .派生类可以调用其_基类 中不具备的数据和操作。55 .利用继承能够实现 软件复用 。这种实现缩短了程序的开发时间,促使开发人员复用已经测试和调试好的高质

14、量软件。56 .当撤消一个含有基类和子对象成员的派生类对象时,将首先完成派生类 一的析构函数定义体的执行,接着完成子对象成员 的析构函数定义体的执行,最后完成基类的析构函数定义体的执行。57 .如果类Alpha继承了类Beta,则类Alpha称为 派生类,类Beta称为_基 类58 .对基类数据成员的初始化必须在派生类构造函数中的 成员初始化列表 处执行。59 .在派生类中使用基类的成员,可以显示地使用成员名BM定符 来使用基类成员60 .当将基类指针转换为派生类指针时,由于编译器认为这种操作是危险的,所以必须要使用强制类型转换 。61 .多继承可以视为是一单继承的扩展,派生类及其基类可用一个

15、 有向无环图DAG 表示。62 .继承是一对象的一个特点,继承支持一层次一类概念。63 .若需要定义一个标识符常量,并且使 C+能够进行类型检查,则应在定义语句的开始使用保留字const .64 .逻辑表达式 x>3&&x<10 的相反表达式为 x<=3|x>=10:65 . 逻辑表达式 a>b 11b = =5 的相反表达式为 a<=b&&b!=5 .66 .假定一个二维数组的定义为“ chara56;则该数组所含元素的个数为_30,所占存储空间的字节数为30.67 .变量分为全局和局部两种,全局变量没有赋初值时,将由系统自

16、动置为 0.68 .假定a是一个一维数组,则ai对应的存储地址(以字节为单位)为 a+i*sizeof (ai)69 .假定一个结构类型的定义为"struct Aint a,b;A *c;”则该类型的大小为 12 字节.70 .假定要访问一个结构指针p所指对象中的b指针成员所指的对象,则表示方法为 _*(p->b).、单选题(每题2分,在下列各题的备选答案中,选出一个正确答案,并将其号码填写在题目后面的括号内。A 1. C+源程序文件的缺省扩展名为 ()A. cpp B. exe C. obj D. likC 2.由C+礴程序文件编译而成的目标文件的缺省扩展名为()A. cpp

17、 B. exe C. obj D. likB 3.由C+目标文件连接而成的可执行文件的缺省扩展名为()A. cpp B. exe C. obj D. lik()。编辑、编译、连接、调试编辑、调试、编辑、连接B 4.编写C+强序一般需经过的几个步骤依次是A.编译、编辑、连接、调试B.C.编译、调试、编辑、连接D.B 5.以下标识符中不全是保留字的是()。A. case for int B. default then whileC. bool class long D. goto return charC 6.能作为C+程序的基本单位是()。A. 字符 B. 语句 C. 函数 D.源程序文件A 7

18、.程序中主函数的名字为()。A. main B. MAIN C. Main D.任意标识符D 8. C+程序的基本模块为()。语句 D. 函数A. 表达式 B. 标识符 C.B 9.可用作C+语言用户标识符的一组标识符是()A. void define +WORD B. a3_b3 _123 YNC. for -abc Case D. 2a DO sizeofD 10.存储以下数据,占用存储字节最多的是()。A. 0 B.,0? C. 0" D. 0.0D 11.程序运行中需要从键盘上输入多于一个数据时,各数据之间应使用()符号作为分隔符。A.空格或逗号B. 逗号或回车 C.逗号或分

19、号D. 空格或回车C 12.设“int a=12; ”,则执行完语句"a+=a*a; "后,a的值是()。A.12 B.144 C.156 D.2881D 13.假设在程序中a、b、c均被定义成整型,所赋的值都大于1,则下列能正确表示代数式的表abc达式是()。A. 1.0/a*b*c B. 1/(a*b*c) C. 1/a/b/(float)c D. 1.0/a/b/cD 14.设“int a=15,b=26;",则"cout<<(a,b);”的输出结果是()。A. 15 B. 26,15 C. 15,26 D. 26C 15.设x是一个b

20、ool型的逻辑量,y的值为10,则表达式x && y的值为()。A. 1 B. 0 C.与x值相同 D. 与x值相反A 16. x>0 && x<=10的相反表达式为()。A. x<=0 | x>10 B. x<=0 && x>10 C. x<=0 | x<=10 D. x>0 && x>10B 17. x>0 | y=5的相反表达式为()。A. x<=0 | y!=5 B. x<=0 && y!=5 C. x>0 | y!=5 D

21、. x>0 && y=5A 18 .设x和y均为bool量,则x && y为真的条件是()。A.它们均为真 B.其中一个为真C.它们均为假D.其中一个为假C 19 .设x和y均为bool量,则x | y为假的条件是()。A.它们均为真B.其中一个为真C.它们均为假D.其中一个为假B 20.字符串"a+b=12n ”的长度为()。A. 6 B. 7 C. 8 D. 9B 21.假定下列x和y均为int型变量,则不正确的赋值为()。A. x+=y+ B.x+=y+ C.x=+y D.+x=+yC 22.下列的符号常量定义中,错误的定义是()。A. c

22、onst M=10; B. const int M=20; C. const char ch; D. const bool mark=true;C 23.循环语句“for(int i=0; i<n; i+) cout<<i*i<<''"中循环体执行的次数为()。A. 1 B. n-1 C. n D. n+1B 24.在下面循环语句中循环体执行的次数为()。for(int i=0; i<n; i+)if(i>n/2) break;A. n/2 B. n/2+1 C. n/2-1 D. n-1D 25.在下面循环语句中内层循环体S

23、语句的执行总次数为()。for(int i=0; i<n; i+)for(int j=i; j<n; j+) S;A. n 2 B. (n+1)/2 C. n(n-1)/2 D. n(n+1)/2C 26.在下面循环语句中循环体执行的次数为()。int i=0,s=0; while(s<20) i+; s+=i;A. 4 B. 5 C. 6 D. 7A 27.在下面循环语句中循环体执行的次数为()。int i=0; do i+; while(i*i<10);A. 4 B. 3 C. 5 D. 2A 28.当处理特定问题时的循环次数已知时,通常采用()来解决。A. for

24、 循环 B. while 循环 C. do 循环 D. switch 语句C 29. 循环体至少被执行一次的语句为( ) 。A. for 循环 B. while 循环 C. do 循环 D. 任一种循环B 30. switch 语句能够改写为( )语句。A. for B. if C. do D. whileD 31. do 语句能够改写为( )语句。A. 复合 B. if C. switch D. whileC 32. 在下面的一维数组定义中,哪一个有语法错误。()A. int a=1,2,3; B. int a10=0; C. int a; D. int a5;D 33. 在下面的字符数组定

25、义中,哪一个有语法错误。() 。A. char a20=” abcdefg ” ; B. char a=” x+y=55. ” ;C. char a15; D. char a10= 5 ;C 34. 在下面的二维数组定义中,正确的是( )。A. int a5; B. int a5; C. int a3=1,3,5,2; D. int a(10);C35.假定一个二维数组的定义语句为“inta34=3,4,2,8,6;” , 则元素a12的值为() 。A. 2 B. 4 C. 6 D. 8A 36.假定一个二维数组的定义语句为“inta34=3,4,2,8,6;” , 则元素a21的值为() 。

26、A. 0 B. 4 C. 8 D. 6B 37. 若定义了函数 double *function(), 则函数 function 的返回值为( ) 。A. 实数型 B. 实数的地址 C. 指向函数的指针 D. 函数的地址B 38. 以下说法中正确的是( ) 。A. C+ 程序总是从第一个定义的函数开始执行B. C+ 程序总是从main 函数开始执行C. C+ 函数必须有返回值,否则不能使用函数D. C+ 程序中有调用关系的所有函数必须放在同一个程序文件中C 39. 以下叙述中不正确的是( ) 。A. 在一个函数中,可以有多条return 语句 B. 函数的定义不能嵌套,但函数的调用可以嵌套C.

27、 函数必须有返回值D. 不同的函数中可以使用相同名字的变量A 40. 函数重载是指( ) 。A. 两个或两个以上的函数取相同的函数名,但形参的个数或类型不同B. 两个以上的函数取相同的名字和具有相同的参数个数,但形参的类型可以不同C. 两个以上的函数名字不同,但形参的个数或类型相同D. 两个以上的函数取相同的函数名,并且函数的返回类型相同C 41. 以下关于函数模板叙述正确的是( ) 。A. 函数模板也是一个具体类型的函数B. 函数模板的类型参数与函数的参数是同一个概念C. 通过使用不同的类型参数,函数模板可以生成不同类型的函数D. 用函数模板定义的函数没有类型C 42. 下列( )的调用方式

28、是引用调用。A.形参和实参都是变量 B.形参是指针,实参是地址值C. 形参是引用,实参是变量D. 形参是变量,实参是地址值A 43. 为了提高程序的运行速度,可将不太复杂的功能用函数实现,此函数应选择( ) 。A. 内联函数 B. 重载函数 C. 递归函数 D. 函数模板8 44. 函数原型语句正确的是( ) 。A. int Function(void a); B.void Function (int);C. int Function(a); D.void int(double a);9 45. C+ 中函数返回值的类型是由( )决定的。A. return 语句中表达式的类型B. 该函数定义时

29、的类型C.调用函数时的调用语句D.系统根据结果A 46. 以下函数的返回结果是( ) 。int function(char *x) char *p=x; while(*p+); return(p-x-1);A. 求字符串的长度 B.将字符串 x 连接到字符串 p 后面C. 将字符串 x 复制到字符串 p 中 D. 将字符串 x 反向存放B 47. 函数调用 func(exp1,exp2),(exp3,exp4,exp5) 中所含实参的个数为 ( ) 个。A.1B.2 C. 4 D. 5B 48. 设有如下函数定义int f(char *s) char *p=s;while(*p!= ?0 ?)

30、 p+;return(p-s);在主函数中用 cout<<f(“good”) 调用上述函数, 则输出结果为( ) 。A. 3 B. 4 C. 5 D. 6C 49. 以下正确的函数原型语句是( )。A. double fun(int x,int y) B. double fun(int x;int y)C. double fun(int,int); D. double fun(int x,y);B 50. 以下正确的说法是( ) 。A. 用户调用标准库函数前,必须重新定义B. 用户可以重新定义标准库函数,若如此,该函数将失去原有含义C. 系统不允许用户重新定义标准库函数D. 用户调

31、用标准库函数前,不必使用预编译命令将该函数所在文件包括到用户源文件中D 51. 函数调用不可以( ) 。A. 出现在一个表达式中B.出现在执行语句中C.作为一个函数的实参D.作为一个函数的形参B 52. 以下正确的描述是( ) 。A.函数的定义可以嵌套,函数的调用不可以嵌套B. 函数的定义不可以嵌套,函数的调用可以嵌套C. 函数的定义和函数的调用均可以嵌套D. 函数的定义和函数的调用均不可以嵌套A 53. 若用数组名作为函数调用的实参,传递给形参的是( ) 。A.数组的首地址 B. 数组中第一个元素的值C. 数组全部元素的值 D. 数组元素的个数D 54. 以下错误的描述是( ) 。A. 被调

32、用函数中可以不用 return 语句B. 被调用函数中可以用多个return 语句C. 被调用函数中,如果有返回值,就一定要有return 语句D. 被调用函数中,一个return语句可返回多个值给调用函数C 55. 以下正确的描述是( ) 。A. 不允许设置参数的默认值B. 设置参数的默认值只能在定义函数时设置C. 设置参数的默认值时,应该设置右边的参数D. 设置参数的默认值时,应该全部参数都设置D 56. 采用重载函数的目的是( ) 。A. 实现共享B. 减少空间 C. 提高速度 D. 使用方便,提高可读性C 57. 将两个字符串连接起来组成一个字符串时,选用( )函数。A. strlen

33、() B. strcap() C. strcat() D. strcmp()B 58. 以下叙述中正确的是( )。A. 使用#define 可以为常量定义一个名字,该名字在程序中可以再赋另外的值B. 使用 const 定义的常量名有类型之分,其值在程序运行时是不可改变的C. 在程序中使用内联函数使程序的可读性变差D. 在定义函数时可以在形参表的任何位置给出缺省形参值C 59. 下面的标识符中, ( ) 是文件级作用域。A.函数形参B. 语句标号 C. 外部静态类标识符 D.自动类标识符D 60. 以下叙述不正确的是( )。A. 宏替换不占用运行时间 B. 宏名无类型C. 宏替换只是字符替 D.

34、 宏名必须用大写字母表示D 61. C+ 语言的编译系统对宏命令的处理是( )。A. 在程序运行时进行B. 在程序连接时进行C.和C+理序的其它语句同时进行编译D.在对源程序中其它成分正式编译之前进行B 62. 当 #include 后面的文件名用双引号括起来时,寻找被包含文件的方式是( )。A. 直接按系统设定的标准方式搜索目录B. 先在源程序所在目录搜索,再按系统设定的标准方式搜索目录C. 仅仅搜索源程序所在目录 D. 搜索当前逻辑盘上的所有目录A 63.当#include后面的文件名用尖括号括起来时,寻找被包含文件的方式是()。A. 直接按系统设定的标准方式搜索目录B. 先在源程序所在目

35、录搜索,再按系统设定的标准方式搜索目录C. 仅仅搜索源程序所在目录D. 搜索当前逻辑盘上的所有目录C 64. 在下面存储类中, ( ) 对象的可见性与生存期不一致。A. 外部类 B. 自动类 C. 内部静态类 D. 寄存器类A 65. 在下面存储类中, ( )的对象不是局部变量。B. 外部静态类 B. 自动类 C. 函数形参 D. 寄存器类C 66. 关于局部变量,下面说法正确的是( )。A.定义该变量的程序文件中的函数都可以访问C. 定义该变量的函数中的定义处以下的任何语句都可以访问D. 定义该变量的复合语句中的定义处以下的任何语句都可以访问E. 定义该变量的函数中的定义处以上的任何语句都可

36、以访问C 67. 文件包含命令中被包含的文件的扩展名( ) 。A.必须是 .h B. 不能是 .h C. 可以是 .h 或 .cpp D. 必须是 .cppB 68. 预处理命令在程序中都是以 ( ) 符号开头的。A. * B. # C. & D. B 69. 设 array 为一个数组,则表达式sizeof(array)/sizeof(array0) 的结果为 ( )A. array 数组首地址B. array 数组中元素个数C. array 数组中每个元素所占的字节D. array 数组占的总字节数C 70.用new运算符创建一个含10个元素的一维整型数组的正确语句是()。A. i

37、nt *p=new a10; B. int *p=new float10;C. int *p=new int10; D. int *p=new int10=1,2,3,4,5A 71. 下列给字符数组赋初值时,正确的是( )。A. char s1=” abcdefB. char s24=”abcd”;C. char s323=“abc”, ”xyz”; D. char s44=,a?, ?x?, ?s?, ?t ?;D 72. 设有定义“ static int data56;” ,设该数组在静态存储区中的起始地址为十进制的100,若每个 int 型数占 4 个字节,则数组元素data23 的地

38、址为 ( )。A. 115B.124C.130D.160B 73.假定变量m定义为“ int m=7; ",则定义变量p的正确语句为()。A. int p=&m; B. int *p=&m; C. int &p=*m; D. int *p=m;D 74. 假定 k 是一个 double 类型的变量,则关于变量p 的正确定义语句为( ) 。A. double p=&k; B. int *p=&k;C. double &p=*k; D. char *p=” Thank you! ”;A 75. 变量 s 的定义为“ char *s= ” H

39、ello world! ”; ”,要使变量p 指向 s 所指向的同一个字符串,则应选取( ) 。A. char *p=s; B. char *p=&s; C. char *p;p=*s; D. char *p; p=&s;C 76. 关于 void 指针,下列说法正确的是( ) 。A. void指针就是未指向任何数据的指针B. void指针就是已定义而未初始化的指针C. 指向任何类型数据的指针可直接赋值给一个void 指针D. void 指针值可直接赋给一个非void 指针D 77.假定一条定义语句为"int a10, x, *pa=a; ",若要把数组a中

40、下标为3的元素值赋给x,则不正 确的语句为( ) 。A. x=pa3; B. x=*(a+3); C. x=a3; D. x=*pa+3;D 78. 假定有定义“ int b10; int *pb; ” ,则不正确的赋值语句为( ) 。A. pb=b; B. pb=&b0; C. *pb=new int; D. pb=b5;C 79.假定p是具有double类型的指针变量,则表达式+p使p的值(以字节为单位)增加()。A. 1 B. 4 C. sizeof(double) D. sizeof(p)C 80. 假定 p 指向的字符串为” string ” ,则 cout<<p

41、+3 的输出结果为( )。A. string B. ring C. ing D. i四、问答题 (每题 10分)1. 为什么称 C+ 语言是混合型面向对象的语言?答:一般真正的向对象语言具有抽象、封装、继承和多态性等特征,完全由一组抽象的对象组成,因此没有全局函数。而C+是在标准C语言的基础上引入“面向对象”概念而扩充形成的,严格地讲,它不是完全由一组抽象的对象(类)组成。因为C+程序中还有像 main这样的全局函数,因此称它为混合型面向对象语言。2. 下面是一个联合的定义:Class CU union int ivalue; float fvalue; /;答:这是一个什么联合的说明?它说明

42、 ivalue 和 fvalue 具有什么关系?这是一个无名联合说明,它说明 ivalue 和 fvalue 共享同一个内存。3. 什么是 C+ 的多态性?答:多态性就是指对一个动作赋予一个名字或符号,该名字或符号在类层次的上下层中是共享的(即用同一个名字) ,而层次中每一个类对该动作的实现是以其适合自己的方式来定义的。在 C+ 中,多态性又被直观地称为“一个名字,多个函数” 。4. 如何通过抽象形成“类”的概念?类的概念来自于什么过程?答: 抽象是一种从一般的观点看待事物的方法,可以将一组对象的共同特征进一步抽象出来,从而形成“类”的概念。类的概念来自于人们认识自然、认识社会的过程。5. 下

43、面是类 C 的定义:class C : public A, private B private:int c; public:void setC(int x, int y )c=x; setB(y);void showC( )showB( ); cout << c << endl;讨论类C属于何种方式的继承及其派生方法对访问基类成员的影响。答:类C是多重继承,它从类 A公有派生,因此,类 A的公有(保护的)成员在类C中仍是公有的(保护的)。类C从类B私有派生,类B的所有成员在类 C中是私有的。6. C+ 的流库预定义了哪几个流?与这几个流所联结的具体设备是什么?答:它们是

44、cin、cout、cerr和clog,与C+的流类库预定义的四个流所联结的具体设备为:cin与标准输入设备相关联cout与标准输出设备相关联cerr与标准错误输出设备相关联(非缓冲方式)clog 与标准错误输出设备相关联(缓冲方式 )7. 在使用 C+ 时,是否应仍然保持 C 语言的习惯及思维方式?为什么?答:不行。做为 C语言的超集,C+在技术上是和 C完全兼容的,但它在概念上是和C语言完全不同的,因此,使用者应该学会按C+ 自己的方式来使用它,掌握C+ 的思维方式、设计方法和习惯。8. C+ 中有哪些机制可以实现命名常量? 答 : 第一个方法是定义const 数据类型, 它不但说明了数据,

45、 而且声明它是常量, 即它的值不能改变。另外一个办法就是利用枚举。9. 简述模板类的动态特征。答:从类系的动态性能角度来看,模板类具有更多的动态特征。一旦完成一个继承类系的设计,它能处理的数据和处理数据的方法就确定了, 除非新继承一个类来完成新的功能。 模板类在设计完成之后,可以处理的数据类型却可以不断增加,并且模板类的实例可在编译时刻初始化,从而具有更好的灵活性。10. .简述静态成员的特性,然后就作用域与全局变量进行比较?答:作为类的静态成员,它的特征是不管类创建了多少个对象,其静态成员都只有一个副本,这个副本为类的所有对象共享。类的静态成员不同于全局变量,全局变量的作用于为整个程序,静态

46、成员只能在类的对象中有效。11. 用指针或引用调用虚函数与通过对象访问虚函数的区别是?答:使用一个基类型的指针(或引用)调用一个虚函数时候, c+ 使用动态联编,而通过对象访问时 候,则使用静态联编。12. 多重继承的构造顺序一般可分为 4 步,下面给出这 4 个步骤:答: 1 ) : 任何虚拟基类的构造函数按照它们被继承的顺序构造。2 ) : 任何非虚拟基类的构造函数按照它们被继承的顺序构造。3 ) : 任何成员对象的构造函数按照它们声明的顺序构造。4 ) : 类自己的构造函数。13. 在 C+ 中,应该使用什么语句来动态分配和释放内存?答: . new , delete14. 下面的程序的

47、正确的输出结果是什么?#include <iostream.h>#include <string.h>class basepublic:virtual char * fun(void)const=0;char * base:fun(void)constreturn "base"class derived1:virtual public basepublic:char * fun(void)constreturn "derived1"class derived2:virtual public basepublic:char * fu

48、n(void)constreturn "derived2"class subderived:public derived1,public derived2public:char * fun(void)constchar * pch;pch=new charstrlen(derived1:fun()+strlen(derived2:fun()+1;strcpy(pch,derived1:fun();strcat(pch,derived2:fun();return pch;void main(void)base * pb;pb=new derived1;cout<<

49、pb->fun()<<endl;pb=new derived2;cout<<pb->fun()<<endl;pb=new subderived;cout<<pb->fun()<<endl;答: . derived1derived2derived1derived29. 目前推荐的 C+ 标准十分虚构造函数?答: . 不支持16 .友元运算符obj会被C+编译器解释为什么?答: . operator(obj)17 .写出下面程序的运行结果。#include <iostream.h>#include <i

50、omanip.h>void print(float a,int count,int width);void main(void)float f2=1.0f,10.0f;cout<<"Default numeric format:"<<endl;print(f,2,10);cout<<"Setting ios:showpoint:"<<endl;cout.setf(ios:showpoint);print(f,2,10);cout.unsetf(ios:showpoint);cout<<&q

51、uot;Setting ios:scientific:"<<endl;cout.setf(ios:scientific);print(f,2,10);cout.unsetf(ios:scientific);void print(float a,int count,int width)for(int i=0;i<count;i+)cout.width(width);cout<<ai<<endl;答:Default numeric format:110Setting ios:showpoint:1.0000010.0000Setting ios:

52、scientific:1.000000e+0001.000000e+00118 . 一个const 对象是否能访问所有成员函数?答:只能访问 const 成员函数19 . 私有与保护之间的区别是什么?答:保护成员在派生类中也可以被访问,而私有成员不可以20、在C+ 中,封装是借助于什么达到的?答:类21、C+可通过什么建立类库?答:继承22、用于类中虚成员函数说明的关键字是什么?答: Bvirtual23 . 完成下面的类定义。Class MyClasspublic:MyClass()x=0; int GetNum( my);private:int x;int GetNum( my)_retu

53、rn my.x;friend MyClass24 . 在下面程序的横线处填上适当的语句,使类型该程序执行结果为10#include <iostream.h>class MyClasspub1ic:/为 x 置值取x值private:int x;void main()Myclass my(10);Cout<<my.GetNum()<<end;MyClass(int a)x=a; int GetNumreturn x;25 . 下面的类中定义了一个关于星期的枚举类型,请完成下面的程序。Class MyClasspublic:enum WeekSun,Mon,Tu

54、e,Wed,Thu,Fri,Sat;Week week;void fun(MyClass &my)= ;_/将对象my 的 week 赋值为所定义的枚举类型 / 值为 3 的枚举量my.week Wed26 . 下列程序将x,y 和 z 按从小到大的顺序排列,在划线处填入正确的内容。Template <class T> void order( )if(x>y)a=x;x=y;y=a;if(y>z)a=y;y=z;z=a;if(x>y)a=x;x=y;y=a;T&x,T&y,T&zT a27 .什么是数据封装?答: 所谓数据封装, 就

55、是将一组数据和与这组数据有关的操作集合组装在一起, 形成一个能动的实体, 也就是对象。28 什么叫做支配规则?答: 类 X 中的名字 N 支配类 Y 中同名的名字N, 是指类 X 以类 Y 为它的一个基类, 这称为支配规则。29 . 为什么引入函数模板和类模板?答:可能常常会遇到这样一种情况:对于很多的数据类型,需要提供一种逻辑功能完全一样的函数,而编制这些函数所提供的程序文本完全一样,其区别仅仅是处理的数据类型不同。对于这种函数,以前常常有两种实现方法,一种方法是用宏函数,另一种方法则是为各种类型都重载这一函数。宏函数虽然方便,但是有时常常引入一些意想不到的问题,从 C+ 开始已经不提倡使用宏;而为各种数据类型重载又显得有点麻烦。希望提供一种更方便更可靠的方法来完成这一功能,函数模板就是适应这一要求而产生的。常常会遇到这样一种情况:为了达到一些相似的功能,需要提供一系列的类,这些类除了一些成员数据类型和一些相关函数处理的数据类型有些不同之外, 别无差异。 与函数模板相对应, C+ 用类模板来完成这一功能。30 .在使用 C+ 时,是否应仍然保持 C 语言的习惯及思维方式?为什么?答:不行。做为 C语言的超集,C+在技术上是和 C完全兼容的,但它在概念上是和C语言

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论