搜索
您的当前位置:首页C++复习题2

C++复习题2

时间:2023-11-15 来源:乌哈旅游
第1章 基本数据与表达式

1.1选择题

1.在一个C++程序中,main函数的位置( c )。

(a) 必须在程序的开头 (b) 必须在程序的后面 ( c ) 可以在程序的任何地方 (d) 必须在其它函数中间 2.用C++语言编制的源程序要变为目标程序必须要经过( d )。 (a) 解释 (b) 汇编 (c) 编辑 (d) 编译 3.C++程序基本单位是( c )。

(a) 数据 (b) 字符 (c) 函数 (d) 语句 4. C++程序中的语句必须以( b )结束。

(a) 冒号 (b) 分号 (c) 空格 (d)花括号 5. 执行C++程序时出现的“溢出”错误属于( c )错误。 (a) 编译 (b) 连接 (c) 运行 (d) 逻辑 6.下列选项中,全部都是C++关键字的选项为( c )。 (a) while IF static (b) break char go (c) sizeof case extern (d) switch float integer 7. 按C++标识符的语法规定,合法的标识符是( a ,c )。 (a) _abc (b) new (c) int1 (d) “age” 8.下列选项中,( a )不是分隔符。 (a) ? (b) ; (c) : (d) () 9.下列正确的八进制整型常量表示是( b )。

(a) 0a0 (b) 015 (c) 080 (d) 0x10 10.下列正确的十六进制整型常量表示是( a,b,d )。

(a) 0x11 (b) 0xaf (c) 0xg (d) 0x1f

11.在下列选项中,全部都合法的浮点型数据的选项为( a,b,d ),全部都不合法的浮点型数据选项是( c )。

(a) -1e3 , 15. , 2e-4

(b) 12.34 , -1e+5 , 0.0

(c) 0.2e-2.5 , e-5 (d) 5.0e-4 , 0.1 , 8.e+2 12.下列正确的字符常量为( b,d )。 (a) \" a \" (b) '\\0' (c) a (d) '\\101' 13.下列选项中,( a,b,c )能交换变量a和b的值。

(a) t=b ;b=a ;a=t; (b) a=a+b ;b=a-b ;a=a-b; (c) t=a ;a=b ;b=t; (d) a=b ; b=a ; 14.执行语句

int i = 10,*p = &i;

后,下面描述错误的是( a )。 (a) p的值为10

(b) p指向整型变量i

(c) *p表示变量i的值 15.执行语句

(d) p的值是变量i的地址

int a = 5,b = 10,c;int *p1 = &a, *p2 = &b; 后,下面不正确的赋值语句是( b )。 (a) *p2 = b; (b) p1 = a;

(c) p2 = p1; (d) c = *p1 *(*p2); 16.执行语句

int a = 10,b;int &pa = a,&pb = b;

后,下列正确的语句是( b )。

(a) &pb = a; (b) pb = pa; (c) &pb = &pa; (d) *pb = *pa; 17.执行下面语句后,a和b的值分别为( b )。 int a = 5,b = 3,t; int &ra = a;

int &rb = b;

t = ra;ra = rb;rb = t; (a) 3和3 (a) <=

(b) 3和5 (b)*=

(c) 5和3 (c)+

(d) 5和5 (d)*

18. 在下列运算符中,( d )优先级最高。

19. 在下列运算符中,( d )优先级最低。 (a) ! (b)&& (c)!= (d)?: 20.设i=1,j=2,则表达式i+++j的值为( c )。

(a) 1 (b)2 (c)3 (d)4 21.设i=1,j=2,则表达式 ++i+j的值为( d )。 (a)1 (b)2 (c)3 (d)4 22.在下列表达式选项中,( c )是正确。

(a)++(a++) (b)a++b (c)a+++b (d)a++++b 23.已知i=0,j=1,k=2,则逻辑表达式 ++i||--j&&++k的值为( b )。 (a) 0 (b)1 (c)2 (d)3 24. 执行下列语句后,x的值是( d ),y的值是( c )。 int x , y ;

x = y = 1; ++ x || ++ y ;

(a) 不确定 (b) 0 (c) 1 (d) 2

25.设X为整型变量,能正确表达数学关系1< X < 5的C++逻辑表达式是( b, c, d )。 (a) 1后,x的值为( c )。

(a)25 (b)40 (c)-40 (d)20

27. 设a=1,b=2,c=3,d=4,则条件表达式a(b)20

(c)100

(d)45

----------------------------------------------------------------------------------------------------------------------

第2章 程序控制结构

2.1选择题

1.已知 int i,x,y;在下列选项中错误的是( c )。 (a) if(x == y)i++; (b) if(x = y)i--;

(b) X==2||X==3||X==4

(d) !(X<=1)&&!(X>=5)

(c) if( xy )i--; (d) if( x+y )i++;

2.设有函数关系为y= ,下面选项中能正确表示上述关系为( c )。 (a) y = 1; (b) y = -1; if( x>=0 ) if( x!=0)

if( x==0 )y=0; if( x>0 )y = 1; else y = -1; else y = 0

(c) if( x<=0 ) (d) y = -1;

if( x<0 )y = -1; if( x<=0 ) else y = 0; if( x<0 )y = -1; else y = 1; else y = 1; 3.假设i=2,执行下列语句后i的值为( b )。 switch(i) { case 1:i++; case 2:i--;

case 3:++i;break; case 4:--i; default:i++; } (a) 1 (b) 2

(c) 3 (d) 4

4.已知int i=0,x=0;下面while语句执行时循环次数为( d )。 while(!x && i<3 ){ x++;i++;}

(a) 4 (b) 3 (c) 2 (d) 1

5.已知int i=3;下面do_while 语句执行时循环次数为( b )。 do{ i--; cout<(a) 0 (b) 5 (c) 10 7.以下死循环的程序段是( b )。 (a) for(int x=0;x<3 ;){ x++;}; (b) int k=0;

do { ++k;} while( k>=0 ); (c) int a=5;while(a){ a--;}; (d) int i=3;for(;i;i--);

----------------------------------------------------------------------------------------------------------------------

第3章 函 数 3.1 选择题

1.以下正确的函数原型为( d )。

(a) f( int x; int y ); (b) void f( x, y ); (c) void f( int x, y ); (d) void f( int, int );

2.有函数原型 void fun1( int ); 下面选项中,不正确的调用是( c )。

(d) 无限

(a) double x = 2.17 ; fun1( x );

(b) int a = 15 ; fun1( a*3.14 ) ; (c) int b = 100 ; fun1( & b ); (d) fun1( 256 );

3.有函数原型 void fun2( int * ); 下面选项中,正确的调用是( c )。 (a) double x = 2.17 ; fun2( &x ); (b) int a = 15 ; fun2( a*3.14 ); (c) int b = 100 ; fun2( &b ); (d) fun2( 256 );

4.有函数原型 void fun3( int & ); 下面选项中,正确的调用是( c )。 (a) int x = 2.17; fun3( &x ); (b) int a = 15; fun3( a*3.14 ); (c) int b = 100; fun3( b ); (d) fun3( 256 ) ;

5.有声明 int fun4( int ); int (*pf)(int) = fun4; 下面选项中,正确的调用是( c )。

(a) int a = 15 ;int n = fun4( &a ); (b) int a = 15; cout<注意:选项(b)也可以调用函数fun4,但由于实参为浮点型表达式,VC6编译器将出现与形参类型不匹配的警告。

6.在VC中,若定义一个函数的返回类型为void,以下叙述正确的是( a,c )。 (a) 用语句调用函数 (b) 用表达式调用函数 (c) 没有返回值 (d) 通过return语句可以返回指定值 7.函数参数的默认值不允许为( c )。

(a) 全局常量 (b) 全局变量 (c) 局部变量 (d) 函数调用 8.使用重载函数编程序的目的是( a )。 (a) 使用相同的函数名调用功能相似的函数 (c) 提高程序的运行速度 9.下列的描述中( b )是错误的。

(b) 共享程序代码 (d) 节省存贮空间

(a) 使用全局变量可以从被调用函数中获取多个操作结果

(b) 局部变量可以初始化,若不初始化,则系统默认它的值为0 (c) 当函数调用完后,静态局部变量的值不会消失 (d) 全局变量若不初始化,则系统默认它的值为0

10.下列选项中,( c ,d )的具有文件作用域。 (a) 语句标号 (b) 局部变量 (c) 全局变量

(d) 静态全局变量

----------------------------------------------------------------------------------------------------------------------

第4章 数 组 4.1 选择题

1.以下对一维数组 a 的正确定义是( c )。

(a) int n = 5, a[n]; (b) int a(5); (c) const int n = 5; int a[n]; (d) int n; cin>>n; int a[n]; 2.下列数组定义语句中,不合法的是( a )。

(a) int a[3] = { 0, 1, 2, 3 }; (b) int a[] = { 0, 1, 2 };

(c) int a[3] = { 0, 1, 2 }; (d) int a[3] = { 0 };

3.已知 int a[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }, *p = a ;则不能表示数组 a 中元素的式子是( c )。 (a) *a (b) *p (c) a (d) a[ p-a ] 4.已知 int a[] = { 0, 2, 4, 6, 8, 10 }, *p = a ; 值不等于0的表达式是( b,d )。 (a) *(p++) (b) *(++p) (c) *(p-- ) (d) *(--p) 5.以下不能对二维数组a进行正确初始化的语句是( c )。 (a) int a[2][3] = { 0 };

(b) int a[][3] = { { 0, 1 }, { 0 } };

(c) int a[2][3] = { { 0, 1 }, { 2, 3 }, { 4, 5 } }; (d) int a[][3] = { 0, 1, 2, 3, 4, 5 };

6.已知int a[][3] = { { 0, 1 }, { 2, 3, 4 }, { 5, 6 }, { 7 } } ;则 a[2][1]的值是( c )。 (a) 0 (b) 2 (c) 6 (d) 7

7.已知int a[3][3] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 } ; 则不能表示数组元素a[2][1]的地址是( a,b )。 (a) &[2][1] (b) *(a[2]+1) (c) a[2]+1 (d) *(a+2)+1 8.已知char *a[]={ \"fortran\则 cout<(a) gets和puts函数可以输入输出包含空格的字符串 (b) cin不能输入包含空格的字符串

(c) cout不能输出包含空格的字符串

(d) 使用赋值运算符可以对字符数组整体赋值 11.下列描述中,错误的是( c )。 (a) 输出字符指针就是输出字符串

(b) 输出字符指针的间接引用就是输出单个字符 (c) 具有相同字符的两个字符串常量相等 (d) 两个数组名的比较是地址的比较

12.判断字符串s1和s2是否相等的表达式为( d )。 (a) s1=s2 (b) s1==s2 (c) strcpy(s1,s2)==0 (d) strcmp(s1,s2)==0 13.判断字符串s1是否大于字符串s2的表达式为( c )。 (a) s1>s2

(b) strcmp(s1,s2)==0

(c) strcmp(s1,s2)>0 (d) strcmp(s2,s1)>0

----------------------------------------------------------------------------------------------------------------------

第5章 类与对象

5.1 选择题

1. 在下列结构变量的定义中,不正确的是( d )。 (a) struct employee { char name[ 20 ] ;

long code ; } emp ; (b) struct

{ char name[ 20 ] ; long code ; } emp ;

(c) struct employee { char name[20]; long code; } ;

employee emp; (d) struct

{ char name[20]; long code; } employee;

employee emp;

2.已知有职工情况结构变量emp定义为: struct employee { char name[ 20 ] ; long code ; struct

{ int year ;

int month ;

int day ; } birth ; } emp ;

下列对 emp 的 birth 正确赋值方法是( d )。 (a) year = 1980 ; month = 5 ; day = 1 ;

(b) birth.year = 1980 ; birth.month = 5 ; birth.day = 1 ;

(c) emp.year = 1980 ; emp.month = 5 ; emp.day = 1 ;

(d) emp.birth.year = 1980 ; emp.birth.month = 5 ; emp.birth.day = 1 ; 3.假定有以下声明和定义,则下面引用形式错误的是( b )。 struct student { int num ; float score ;

} stu[3] = {{1001,80},{1002,75},{1003,91}}, *p = stu ; (a) p->num (b) (p++).num (c) (p++)->num 4.下列四个运算符中,优先级最低的是( a )。 (a) ++ (b) . (c) -> 5.若有以下声明和定义,则下列错误的引用是( d )。 struct worker { int no ;

char name[ 20 ] ;

(d) (*p).num (d) ()

} w, *p = &w ;

(a) w.no (b) p->no (c) (*p).no (d) *p.no 6.若有以下声明和定义,则下列引用非法的是( d )。 struct data { int n; float score; data *q ;

};

data a[3] = {1001,87,&a[1],1002,75,&a[2],1003,90,&a[0]}; data *p = a; (a) p->n++

(b) (*p).n++

(c) ++p->n

(d) *p->n

7.关于类和对象不正确的说法是( c )。

(a) 类是一种类型,它封装了数据和操作 (b) 对象是类的实例 (c) 一个类的对象只有一个 (d) 一个对象必属于某个类

8.在类定义的外部,可以被访问的成员有( c )。 (a) 所有类成员 (b) private或protected的类成员 (c) public的类成员 (d) public或private的类成员 9.关于this指针的说法错误的是( a,d )。 (a) this指针必须显式说明

(b) 当创建一个对象后,this指针就指向该对象 (c) 成员函数拥有this指针

(d) 静态成员函数拥有this指针 10.声明一个类的对象时,系统自动调用( b,d )函数;撤消对象时,系统自动调用( 函数。

(a) 成员函数 (b) 构造函数 (c) 析构函数 (d) 复制构造函数 11.下面对构造函数的不正确描述是( b )。 第7章 (a) 系统可以提供默认的构造函数 (b) 构造函数可以有参数,所以也可以有返回值 (c) 构造函数可以重载

(d) 构造函数可以设置默认参数

12.下面对析构函数的正确描述是( a,c )。 (a) 系统可以提供默认的析构函数 (b) 析构函数必须由用户定义 (c) 析构函数没有参数 (d) 析构函数可以设置默认参数 13.对静态成员的不正确描述是( c,d )。 (a) 静态成员不属于对象,是类的共享成员 (b) 静态数据成员要在类外定义和初始化

(c) 调用静态成员函数时要通过类或对象激活,所以静态成员函数拥有this指针 (d) 只有静态成员函数可以操作静态数据成员 14.下面选项中,不是类的成员函数为( c )。

(a) 构造函数 (b) 析构函数 (c) 友元函数 (d) 复制构造函数 15.下面对友员的错误描述是( d )。 (a) 关键字friend用于声明友员

(b) 一个类中的成员函数可以是另一个类的友员 (c) 友员函数访问对象的成员不受访问特性影响

c ) (d) 友员函数通过this指针访问对象成员

----------------------------------------------------------------------------------------------------------------------

第6章 运算符重载

6.1 选择题

1.在下列运算符中,不能重载的是( b )。 (a) ! (b) sizeof (c) new

(d) delete

(d) &=

2. 在下列运算符中,不能重载的是( c )。 (a) <= (b) >> (c) && 3.下列关于运算符重载的描述中,( d )是正确的。

(a) 可以改变参与运算的操作数个数 (b) 可以改变运算符原来的优先级 (c) 可以改变运算符原来的结合性 (d) 不能改变原运算符的语义 4.下列函数中,能重载运算符的函数是( b,c )。 (a) 成员函数 (b) 构造函数 (c) 析构函数 (d) 友员函数 5.不能用友员函数重载的是( a )。 (a) = (b) == (c) +=

(d) !=

6.下面描述中,错误的是( b )。

(a) 只有系统预先定义的运算符才可能被重载

(b) 使用类型转换函数不能把一个类转换为另一个类

(c) 使用类型转换函数可以把类转换为基本类型

(d) 类型转换函数只能定义为一个类的成员函数,不能定义为类的友员函数

----------------------------------------------------------------------------------------------------------------------

第7章 继 承

7.1 选择题

1.在c++中,类与类之间的继承关系具有( c )。

(a) 自反性 (b) 对称性 (c) 传递性 (d) 反对称性 2.下列关于类的继承描述中,( a,b )是错误的。

(a) 派生类可以访问基类的所有数据成员,调用基类的所有成员函数 (b) 派生类也是基类,所以基类具有派生类的全部属性和方法

(c) 继承描述类的层次关系,派生类可以具有与基类相同的属性和方法 (d) 一个基类可以有多个派生类,一个派生类可以有多个基类

3.当一个派生类公有继承一个基类时,基类中的所有公有成员成为派生类的( a )。 (a) public 成员 (b)private成员 (c) protected成员 (d)友员

4.当一个派生类私有继承一个基类时,基类中的所有公有成员和保护成员成为派生类的( b )。 (a) public 成员 (c) protected成员

(b)private成员 (d)友员

5.当一个派生类保护继承一个基类时,基类中的所有公有成员和保护成员成为派生类的( c )。

(a) public 成员 (b)private成员 (c) protected成员 (d)友员

6.不论派生类以何种方式继承基类,都不能使用基类的( b )。

(a) public 成员 (b)private成员

(c) protected成员 (d)public 成员和protected成员 7.下面描述中,错误的是( b, c )。

(a) 在基类定义的public成员在公有继承的派生类中可见,也能在类外被访问

(b) 在基类定义的public和protected成员在私有继承的派生类中可见,在类外可以被访问 (c) 在基类定义的public和protected成员在保护继承的派生类中不可见 (d) 在派生类中不可见的成员要变成可访问的需进行访问声明 8.在c++中,不能被派生类继承的函数是( b )。 (a) 成员函数 (b)构造函数 (c) 非静态成员函数 (d)静态成员函数 9.在创建派生类对象时,构造函数的执行顺序是( d )。 (a) 对象成员构造函数、基类构造函数、派生类本身的构造函数 (b) 派生类本身的构造函数、基类构造函数、对象成员构造函数 (c) 基类构造函数、派生类本身的构造函数、对象成员构造函数 (d) 基类构造函数、对象成员构造函数、派生类本身的构造函数 10.当不同的类具有相同的间接基类时,有特点( d )。 (a) 各派生类对象将按继承路线产生自己的基类版本 (b) 派生类对象无法产生自己的基类版本

(c) 为了建立惟一的间接基类版本,应该必须改变类格 (d) 为了建立惟一的间接基类版本,应该声明虚继承

----------------------------------------------------------------------------------------------------------------------

第8章 虚函数与多态性

8.1 选择题

1.在C++中,要实现动态联编,必须使用( d )调用虚函数。 (a) 类名 (b) 派生类指针 (c) 对象名 2.下列函数中,可以作为虚函数的是( c,d )。

(d) 基类指针

(a) 普通函数 (b) 构造函数 (c) 成员函数 (d) 析构函数

3.在派生类中,重载一个虚函数时,要求函数名、参数的个数、参数的类型、参数的顺序和函数的返回值( b )。

(a) 不同 (b) 相同 (c) 相容 (d) 部分相同 4.下面函数原型声明中,( b )声明了fun为纯虚函数。 (a) void fun()=0; (b)virtual void fun()=0; (c) virtual void fun(); (d)virtual void fun(){ }; 5.若一个类中含有纯虚函数,则该类称为( d )。 (a) 基类 (b) 纯基类 (c) 派生类 (a) Aclass fun( int ) ; (b)Aclass * p ; (c) int fun( Aclass ) ; (d)Aclass Obj ;

7.下面描述中,正确的是( b,d )。 (a) 虚函数是没有实现的函数 (b) 纯虚函数的实现在派生类定义

(c) 抽象类是只有纯虚函数的类 (d) 抽象类指针可以指向不同的派生类

----------------------------------------------------------------------------------------------------------------------

(d) 抽象类

6.假设 Aclass为抽象类,下列声明中( b )是正确的。

第11章 输入/输出流

10.1 选择题

1.下列类中( b,d )不是输入输出流类iostream的派生类。 (a)fstream (b)ofstream (c)strstream (d)ostrstream 2.在下列选项中( b,c,d )是ostream类的对象。

(a)cin (b)cerr (c)clog (d)cout 3.read函数的功能是从输入流中读取( d )。

(a)一个字符 (b)当前字符 (c)一行字符 (d)指定若干个字符 4.下列选项中,用于清除基数格式位设置以十六进制输出的语句是( b )。 (a) cout<(d) cin >>setf( ios::hex,ios::basefield);

5.下列格式控制符,在iostream.h中定义的是( a,d ),在iomanip.h中定义的是( b,c )。 (a)endl (b)setfill (c)setw (d)oct

6.下列串流类,在strstream.h中定义的是( b,d ),在sstream.h中定义的是( a,c )。 (a)istringstream (b)istrstream (c)ostringstream (d)ostrstream 7. 包含类fstream定义的头文件是( a )。

(a)fstream.h (b)ofstream.h (c)ifstream.h (d)iostream.h 8.以写的方式打开文件 ” D:\\file.dat”,错误的语句是( a,b,c,d )。 (a) ifstream infile( “D:\\file.dat”, ios::in );

(b) ifstream infile( “D:\\\\file.dat”, ios::in); (c) ofstream infile( “D:\\file.dat”, ios::out);

(d) fstream infile( “D:\\\\file.dat”, ios::in|ios::out );

9.假定已定义浮点型变量data,以二进制方式把data的值写入输出文件流对象outfile中去,正确的语句是( c )。

(a) outfile.write(( float* ) &data , sizeof( float )); (b) outfile.write(( float* ) &data , data );

(c) outfile.write(( char* ) &data , sizeof( float )); (d) outfile.write(( char* ) &data , data );

因篇幅问题不能全部显示,请点此查看更多更全内容

Top