C++面向对象程序设计考试试卷(详细讲解) 下载本文

内容发布更新时间 : 2024/11/10 4:42:24星期一 下面是文章的全部内容请认真阅读。

C++面向对象程序设计 考试试卷(详细讲解)

一、 单项选择题(共20题,每题1分,共20分)

1、下列关于C++标识符的命名不合法的是 C 与C#一样 A. Pad B. name_1 C. A#bc D. _a12 2、若有以下类型标识符定义: ( )D

int x=2; char w='a'; float y=23.45f; double z=45.6712; 则表达式w*x+y-z的结果类型是 A. float B. char C. int D. double

6、对重载函数形参的描述中,错误的是 D 重载是重点 A. 参数的个数可能不同 B. 参数的类型可能不同 C. 参数的顺序可能不同

D. 参数的个数、类型、顺序都相同,只是函数的返回值类型不同 7、以下能正确定义数组并正确赋初值的语句是 D A. int N=5,b[N][N];

B. int a[2]={{1},{3},{4},{5}}; C. int c[2][]={{1,2},{3,4}}; D. int d[3][2]={{1,2},{3,4}};

8、下列给字符数组进行的初始化中,不正确的是 D A. char s1[]=\B. char s2[3]={'x','y','\\0'}; C. char s3[]={'a','x','y','\\0'}; D. char s4[6]={\

9、通常的拷贝构造函数的参数是 C A. 某个对象名 B.某个对象成员名 C. 某个对象的引用 D.某个对象的指针名 10、关于构造函数特点的描述中,错误的是 A

A. 定义构造函数必须指出类型 (构造函数特点是无返回类型) B. 构造函数的名字与该类的类名相同

C. 一个类中可定义0至多个构造函数 (不写构造函数,系统会自动生成一个空的构造函数) D. 构造函数是一种成员函数

12、关于常成员的描述中,错误的是 B A. 常成员包含常数据成员和常成员函数两种 B. 常数据成员必须是公有的

C. 常数据成员要使用构造函数成员初始化列表进行初始化 D. 常对象只能调用它的常成员函数,不能调用其它的成员函数

16、若数组名作实参而指针变量作形参,函数调用时实参传给形参的是 D A. 数组的长度 B. 数组第一个元素的值 C. 数组所有元素的值 D. 数组第一个元素的地址

17、对于动态分配内存空间描述正确的是 D A.使用new运算符分配的内存空间的长度必需是常量

- 1 -

B.delete运算符可以释放动态的存储空间和静态的存储空间 C.由new分配的内存空间是不连续的

D.delete运算符只能释放由new分配的动态存储空间 18、能够释放对象所占资源的是 ( ) A A.析构函数 B.数据成员 C.构造函数 D.静态成员函数

二、 填空题(共9题16空,每空1分,共16分)

1、函数重载时,编译系统会根据__形参的类型__ 或__形参的个数__ 来区分。与返回类型无关 2、若有char a[80];则cin>>a表示从键盘上读入一个__字符串__ 到数组a中。

3、若希望用一个已有对象来构造另一个同类型的对象,可以使用__拷贝构造函数__来实现。 4、静态成员(static)属于__类__ ,而不属于__任何一个对象__ ,它被同一个类的所有对象共享。 5、类的继承方式有____ 继承、____ 继承和____ 继承。 public(或公有) private(或私有) protected(或保护)

6、重载运算符的含义必须清楚,不能有__二义性__ 。 三、 判断题

1、关系运算符可以用来比较两个字符的大小,也可用来比较两个字符串的大小。)× 2、字符串\的长度是3。√占用空间是4,字符串有个结尾符号占空间。 3、引用和指针都可作函数参数。√ 4、析构函数不能被继承。√

5、在C++中,函数名实际上是一个指针,它指向函数的入口。√

四、

阅读程序,写出运行结果

1、 #include int func(int a) { int b=0;

static int c=4; //静态变量 b++; c--; return(a+b+c); }

void main( ) { int a=2;

for(int j=0;j<2;j++) cout< class X {

- 2 -

public: X(int i)

{ x=i; cout<<”int: ”<

{ x=(int)i*2; cout<<” double: ”<

{ cout<<” ~X(): ”<

void main() { int a=8; double b=11.0; X x1(55), x2(a*5); X x3=X(2*a); X x4=X(b); }

输出结果为:int:55,called // X1被创建 int:40,called //x2被创建 int:16,called //x3被创建

double:11,called //x4被创建 x值为22,显示的是i值,不改变 ~x<>:22,called //析构函数的调用顺序与构造函数调用顺序相反 ~x<>:16,called ~x<>:40,called ~x<>:50,called 六、编写程序

1、输入一组数据以-1作为结束标志,要求删除其它数据只保留能被2整除的数据并输出结果。 # include void main() {

int b[50],x,n=0; cin>>x; while(x!=-1) { b[++n]=x; cin>>x; }

for(int i=1,j=0;i<=n;i++) if(b[i]%2==0) b[++j]=b[i]; for(i=1;i<=j;i++) cout<

- 3 -