|
谋学网(www.mouxue.com)是国内最专业的奥鹏作业资料,奥鹏离线作业资料及奥鹏毕业论文辅导型网站,主要提供奥鹏中医大、大工、东财、北语、北航、川大、南开等奥鹏作业资料辅导,致力打造中国最专业的远程教育辅导社区。
2 @' e1 t% \ {/ s: J5 h' D0 q" k2 R& S* l
5 U8 V1 A: p, l- J
一、单选题(共 35 道试题,共 70 分。)V 1. 友元重载运算符obj1>obj2被C++编译器解释为()。 v( x5 k. C/ d, z/ f
A. operator>(obj1,obj2)
- ]5 ]% ]* r# `$ h0 e5 ~. h) Z+ O2 XB. >(obj1,obj2): A' [* ]& @7 C# z
C. obj1.operator>(obj2) q9 ?" i% }5 y. o4 p2 @) b
D. obj2.operator>(obj1)
4 d" ?" I& B+ U- r" A# A 满分:2 分
) Z6 ^+ B& s( G5 Y2. 结构化程序设计方法以()为中心进行分析和设计。
1 B S& ~ ~/ H4 E6 E. r" x9 RA. 结构. ]7 s) `9 j' {* Y! s4 g7 e- F
B. 模块
) D' g$ g8 N% O- ?* l; IC. 对象
7 e; T: p5 s7 @" sD. 类, p! g% D5 c; k9 }% j4 a
满分:2 分
6 \; `( c0 e9 b, j* V5 y3. 变量的引用,其含义是指该变量的()。
r$ ~" ?7 t: w( Q, f' k) R2 UA. 值% o. E# P* {; T" J
B. 类型
) W9 m" s4 @; r8 K, S0 f# x( CC. 别名
( b- X6 Z, L N( |$ q9 ]9 b4 aD. 地址
0 X$ H u! ]8 J' R 满分:2 分1 X2 K; ^6 J. A: b3 C0 O9 F
4. 多继承的构造函数顺序可分为如下4步: ①所有非虚基类的构造函数按照它们被继承的顺序构造。 ②所有虚基类的构造函数按照它们被继承的顺序构造。 ③所有子对象的构造函数按照它们声明的顺序构造。 ④派生类自己的构造函数体这四个步骤的正确顺序是()。
A2 i+ s- \. ~* uA. ④③①②
0 _. O( D: Y4 _; x( x" t& T/ A( YB. ②④③①8 C0 n1 {: \8 N4 R/ B8 h1 D# L
C. ②①③④; e# {/ h% O3 l( }9 {' T' X- n
D. ③④①②
0 I) ?/ ^ u+ M9 Y" c 满分:2 分
( i q( ?! ]. P- k7 G$ c. L1 ^5. 在使用类创建对象时,系统会自动调用该对象的()完成对象中数据成员的初始化等操作。* b/ Y1 g% C! G \- T
A. 友元函数
2 b1 ^1 \/ _+ D2 \B. 虚函数% C+ k$ Q1 Z( s0 ^2 [& u \
C. 构造函数; V5 c0 B6 q$ K" x* h' u) t+ m
D. 析构函数; R" G$ Y z R7 `4 X
满分:2 分
9 u: E7 Q/ `( r9 ]8 C, K5 q6. 在一个string类对象表示的字符串中查找子串,应该使用string类的()函数。
. X! W: s9 J" D7 a& H: H9 V( I6 _A. assign- k3 ], t6 l# U+ O
B. insert
+ _! K1 h8 o; BC. swap
$ S" b1 Z* {, |: V: _6 X" aD. find e2 I9 I) f$ d! m3 E9 n0 g# }& X7 f
满分:2 分
, j& b7 e2 {# c& E; Z+ X+ f7. 类aClass的定义如下: class aClass {public: aClass(){} aClass(int i){value=new int(i);} int *value; } 若要对类中的value赋值,则下面的语句中,正确的是()。
; i" R9 L, P: f4 f, X4 gA. aClass my; my.value=10;
% b3 Y' a' U8 l3 [B. aClass my; *my.value=10;
1 w6 C9 [' |) w9 G; S! r9 G5 @- nC. aClass my; my.*value=10;# r0 R( k1 r! U. s' G$ O/ G4 ]7 I
D. aClass my(10);
% a' Y, ~' r$ N! P+ e 满分:2 分
5 [0 V3 I2 b+ H: ]; X# B5 n ?8. 已知“int a=10,*p;int *&r=p; r=&a;*p=20;cout<<a;”,则输出为()。8 p# F2 L ~6 m" h
A. 10
9 `8 }$ @8 \! M3 c) ]' qB. 20
2 _ z; [2 Z1 i& {# JC. 不确定值
# W5 [' }: v3 z1 x; @, u$ E3 HD. 程序有错误
9 H5 A- N2 {; g9 ]' L% l( [% Z- D 满分:2 分6 a0 n1 w- B4 D% ?3 j' h
9. 已知“float *p; p=new float[2];”,若分配成功,则指针p在堆中获得的字节数为()。
) x6 s! |9 q0 XA. 28 Y- ^/ Y2 c8 J& [- f! z( V# q9 [
B. 4
. h! ]; a' D4 X- o# o/ JC. 80 O: F7 J) c' s5 W$ [% H
D. 不确定, u6 X) s+ J; @
满分:2 分
" ^+ c, J; p7 R1 r8 e3 w' I0 E- F10. 关于纯虚函数和抽象类的描述中,错误的是()。- \7 [! v+ c( j& i* d7 D
A. 纯虚函数是一种特殊的虚函数,它没有具体的实现。
6 a3 h/ y* O5 w7 Y+ p: A; H! RB. 抽象类是指具有纯虚函数的类。. a ]" K" k* q8 G0 V% v7 P( w
C. 一个基类中有纯虚函数,该类的派生类一定不再是抽象类。
9 b& r/ R% x8 B% P* PD. 抽象类作为基类来使用,其纯虚函数的实现由派生类给出。
3 _' J7 l2 t8 c8 r 满分:2 分
# e3 H2 Z5 M% G$ t3 w7 v: B) a5 B11. 假设堆内存分配均成功,则下面程序段完全正确的是()。. Y Y8 M6 m5 g2 A
A. int *p=new int(3);cout<<*p;delete p;; Z( }$ B% c0 l$ n
B. int *p=new int[5]={1,2,3,4,5};for(int i=0;i<5;i++)cout<<p;delete []p;
0 R+ }, O2 Q4 F; a: t3 S. GC. int *p=new int[5];for(int i=0;i<5;i++,p++) {*p=i; cout<<*p;}delete []p;
. n8 Z- \1 d/ X( ]9 ^* RD. 以上程序段均正确, E! ~4 }* i. n+ }, i3 P# C/ }, n
满分:2 分
2 @2 G% ?& W, |' s12. 要在类对象上使用运算符,以下不用必须被重载的运算符是()。3 a2 l f4 f4 ^) ~) `: \' f
A. [ ]8 ^- }3 N h. h# v
B. =
/ o+ U/ s% k* r R, s3 t* FC. ++
: r0 g( A* K" D% tD. --) f. k, @# Z6 e3 R4 [
满分:2 分
( q3 e3 r& n, \4 b5 c13. 在公有派生情况下,有关派生类对象和基类对象的关系,下列叙述不正确的是()。
' O" y: S7 d- H3 S6 S3 R% y% HA. 派生类的对象可以直接访问基类的所有成员) ^" M# H7 P( H! `: O
B. 派生类的对象可以初始化基类的引用* D. V, ?( j0 l% E! V6 a
C. 派生类的对象不可以直接访问基类中的私有成员
5 |# `7 y/ [( V2 {D. 派生类的对象的地址可以赋给指向基类的指针
4 Q' Q% P7 R- c& D5 w) c 满分:2 分+ M, g9 \& _& U- F
14. 下列运算符中,()在C++中不能重载。
I5 F2 `7 `7 d' s: yA. ?:7 H( i. k2 {1 m" k* J# \
B. +' B2 z* A# r" V+ {7 ?
C. -6 j, D( \0 Z0 {% v1 C4 I8 h0 |
D. <=5 D* c: A$ r7 d- v- b; R( T/ g
满分:2 分
2 g! T# ]7 _% T* n$ X- i; {6 r15. 假定MyClass为一类,执行MyClass a,b(2),*p[2];语句时会自动调用该类构造函数()次。. O4 q( v5 p# r+ p
A. 2& a2 l# z* O2 t; ~: j- _/ k
B. 3
/ l9 y `6 O- c( Z) Y1 NC. 4' x8 B. o; v2 I" @- i
D. 57 e, c$ I5 N, ?5 o
满分:2 分
4 l* y6 d) p# L% {16. 类的默认的无参构造函数()。8 s; Z- Q. J W% E
A. 在任何情况下都存在
- @$ v' |6 M6 _' L9 M$ z4 @& F# X; \B. 仅当未定义无参构造函数时存在6 I" k# |6 a. a* U ?
C. 仅当未定义有参构造函数时存在4 }/ \+ d. i( k" ~$ ]2 b0 w
D. 仅当未定义任何构造函数时存在' F2 G* O; m/ z- N9 Q) h
满分:2 分" N3 ^8 c# o5 B
17. 在C++中,通过()的机制可以对原有的类进行扩充和完善以适应新的需要。8 w* D f e( C! }; @. t0 x4 |2 [
A. 继承
) @9 d8 Q7 z, m1 C; CB. 封装
% {" I. g- R, F) w5 d7 KC. 多态
5 y: [4 {/ ]: V0 F( RD. 重载
+ l6 M1 Q" D! V3 H6 [1 V6 n+ P% w 满分:2 分
" K2 X2 |' d% O9 ~( X: l" h; I18. 有如下类声明: class Sample { int x; }; 则Sample类成员x是Sample类的()。0 }8 F/ {& A3 Y4 `* p
A. 公有数据成员7 }, H8 x9 I% f3 T
B. 保护数据成员7 Y4 w I; a" `
C. 私有数据成员+ B* l0 x* R) ?9 F: ?
D. 以上选项都不正确
. V/ S- ?* z8 Y) {$ O# X7 r1 R% t 满分:2 分
6 S) l' e2 ]+ D: V- P0 P. u& s19. 运算符重载的目的是()。
7 g9 l# F. Q3 G& N& jA. 提高程序的效率
$ R9 u6 S5 i( ?. [+ U+ uB. 提高代码复用能力; T* v4 u; T' H( _' f! A
C. 简化程序,减少目标代码
8 E7 t( t! V0 Q4 U1 N) A) l! F: x$ aD. 使程序代码直观易读
0 H' Y% {8 B2 S8 J 满分:2 分6 B1 x* [" x. _1 W
20. 类MyClass的定义如下: class MyClass { public: MyClass() { value = 0;} SetVariable(int i) { value = i; } private: int value; } 则对下列语句序列正确的描述是()。 MyClass *p,my; p=&my;8 x2 j4 P# J3 Q/ g1 `0 j
A. 语句p=&my;是把对象my赋值给指针变量p
, R$ D+ W7 j6 g) WB. 语句MyClass *p,my;会调用两次类MyClass的构造函数. f& d- a- K5 @4 `& ] C
C. 对语句 *p.SetVariable(5)的调用是正确的
" @8 L3 J. @$ b3 O' rD. 语句p->SetVariable(5)与语句my.SetVariable(5)等价+ d6 U8 I% w: X2 Q/ w
满分:2 分 K0 u' t4 |. j9 y$ ]
21. 程序在调用重载函数时,根据()区分到底要调用哪个函数。
& c( A3 [, Z/ i6 P! _! FA. 函数名
3 z) ?1 j$ G" \9 @$ TB. 返回值类型
! U9 u$ z/ W- P' e5 `C. 参数个数和类型
" u# z/ i7 w0 B( oD. 以上都可以
7 h" j8 J: ]( a$ P 满分:2 分 B' c/ ~. X/ z4 |0 M
22. “#include <iostream>”是()预处理命令。
- R \, A: U1 U1 |* b3 m c8 VA. 宏定义) S2 F2 H' J3 V9 y! G5 u
B. 文件包含& [- `4 V3 f# }" ^0 J
C. 条件编译
1 r4 K- y9 |) R& W; g* J, E* A5 q4 pD. 工程配置
9 c# E, b- J1 W6 w1 _0 ^ 满分:2 分: Y, v. o# Q- }" R
23. 面向对象程序设计方法以()为中心进行分析和设计。
- W |9 T6 e2 _- S4 _A. 结构: J* T7 S. i! l6 ?1 O
B. 模块
3 o# F8 H; I$ C4 jC. 对象
& S% m4 ~# ]9 b3 S: nD. 类' F: D, J: `7 ^4 s3 H9 E! x
满分:2 分" W" j5 ~# K0 ?" Q1 i: |8 _
24. 如果一个类至少有一个纯虚函数,那么就称该类是()。( Q b- p3 ]& S. X; F3 R
A. 抽象类
( r' V' x/ x3 K7 a, {3 B; ZB. 虚基类. L' j" h2 }( }5 e
C. 派生类! M7 ^5 P0 h5 ~; R
D. 以上都不对) ?/ p o* U4 W/ l
满分:2 分' e) `& V# O; Z$ S5 K
25. 已知“float *p; p=new float[2];”,若要释放p所指向的堆中的这些字节,下列语句正确的是()。
; e U# k k/ g7 g; cA. delete p;
; `* G1 U3 r _' r' S9 m% K3 v2 xB. delete p[];
. u1 v1 O2 D3 H6 ?2 I' e/ CC. delete []p;
. y) j2 A2 R3 s1 c4 vD. delete p[2];5 F! H- h5 Z! }5 e+ Y# x" a8 N
满分:2 分; x& o \2 [5 [9 D' R
26. 下列对派生类的描述中错误的是()。
. W% c& r! t0 e4 \A. 派生类至少有一个基类4 v& ^. q% R* `9 z
B. 派生类可作为另一个派生类的基类
F) w* ]: u. J; QC. 派生类除了包含它直接定义的成员外,还包含其基类的成员$ w/ y9 U2 U0 Q9 u4 p9 ~
D. 派生类对其继承的基类的成员访问权限保持不变7 t' S( j q1 ~6 F3 E
满分:2 分
; @9 F. U$ r% @7 q9 G27. 若类中有指针成员变量,则应编写(),使得在对象销毁时能够自动调用该函数释放指针成员变量所指向的内存空间。
$ G+ c/ D: c0 H% J0 PA. 友元函数2 U3 N! ?& \! Y6 }0 J2 c
B. 虚函数7 |% j! j; e# r
C. 构造函数
! }( U7 f4 _7 G5 O& z2 L4 |D. 析构函数( ~* ] ]/ @" J7 Z. H# H5 n
满分:2 分/ W; z! Y1 U# h( D' N
28. 对于拷贝构造函数,正确的描述是()。; n* U: p1 E. v1 @; O
A. 在C++语言中,如果不自定义类的拷贝构造函数,则每个类都有默认的拷贝构造函数
7 n6 g2 L; x6 b7 E. o) f- uB. 必须为每个类定义拷贝构造函数 n7 ^' N$ Y0 {: r
C. 如果要使用拷贝构造函数,则必须在类中先定义' I8 H; k4 y5 L
D. 当定义了类的构造函数时,如果要使用拷贝构造函数,则必须定义拷贝构造函数
/ p& Y9 p8 {5 s4 W$ | 满分:2 分, K! S) h" v' a6 ^8 H* u
29. 交换两个string类对象所表示的字符串的内容,应该使用string类的()函数。
3 @# } R: ~4 S' v( ?8 w. G% DA. assign' M# F. g5 {# v* X: D2 ~. d4 g1 b
B. insert
( p |) E2 l* N' O) ~, xC. swap
# s+ }3 o/ q/ g% G5 qD. find
6 O& @' \! n" P1 E 满分:2 分4 U- U" ^. R9 Y/ t% K
30. 任意一个类,析构函数的个数最多是()。6 i) G2 Z4 J* n3 r8 q) q
A. 不限个数6 q/ R, p/ `2 q9 Q
B. 1% L1 w* g" i7 @( ^& y
C. 2
: z3 t( {8 l6 C! U/ _' A/ a M2 CD. 3
# g7 u0 ~; O, q! Q 满分:2 分
5 u; Z: W) I2 d) R+ G31. 下列关于动态联编的描述中,错误的是()。
- N8 t- e- Z7 V% SA. 动态联编是以虚函数为基础的
4 k& k+ B2 m9 F4 }5 T- OB. 动态联编是在运行时确定所调用的函数代码的1 b# S: w/ U9 {' o0 g
C. 动态联编调用函数操作是通过指向对象的指针或对象
9 H% s; p0 v) c2 {# sD. 动态联编是在编译时确定操作函数的
( G; X' r5 v- M" @. h 满分:2 分. X1 C: J" ^, P4 R% H9 |
32. 类对象占用内存的大小与()有关。+ z4 z8 m) f" D# M. ~$ e* p. S% e
A. 数据成员: C" \- T& s8 |1 H m% `" r3 c5 h
B. 成员函数
6 a- {( l- O# p: Q" ~ A- k# l8 BC. 数据成员和成员函数$ ]8 Z# f, D7 U* T, [5 ?* R
D. 私有成员, j( T) Q( E O6 D
满分:2 分
# W* Y/ N' n0 w. G( C33. 以下为重载函数的一组函数声明的是()。
; i, U k" o/ U9 @5 d" r" SA. void print(int); void print(double);" l8 b! x+ V; `1 i. [( p+ J
B. void fun(int); int fun(int);4 j M; U1 p7 x0 A! v
C. int max(int,int); int min(int,int);! {( ?9 p; Q, m4 q5 [- P' G
D. void mm(); int mm();
! g4 C: ^, L# t9 s" [. g 满分:2 分
/ @2 G* U( `) r3 N" t* D34. 运行以下程序时,如果由键盘输入65 14,则输出结果是()。 #include <iostream> using namespace std; int main() { int m, n; cout<<"Input m, n:"; cin>>m>>n; while(m!=n) { while(m>n) m-=n; while(n>m) n-=m; } cout<<m<<endl; return 0; }
: Y) X9 d0 v4 { T) E- U; a: P1 h7 MA. 3% A! Q% ?- [* G: z* F( d
B. 28 y/ i: A/ x9 w: b( u
C. 1
1 W( @6 z& ^1 s8 a( X6 oD. 0
$ T, \6 O, M9 U% e# C! ^- w 满分:2 分
5 B- u) \$ j3 O: d35. 下列关于运算符重载正确的是()。
- [5 l: `: L( K: y O8 Z5 vA. 运算符重载可以改变运算符的操作数个数8 C% `' n( g& v1 [* P
B. 运算符重载可以改变运算符的优先级
: k) R/ ?( ~& }' c7 QC. 运算符重载可以改变运算符的结合性0 ~! ~! f/ n+ F# T: r6 |
D. 运算符重载不可以改变语法结构, C9 {) ]1 {/ M& |
满分:2 分 4 \, K9 G( @" Q( Y$ H
" M9 V$ S' w: F9 Q. m- H& B二、判断题(共 15 道试题,共 30 分。)V 1. 私有继承中,对于基类中的所有成员,派生类的成员函数都不可直接访问。
1 _' V, ~- ]4 |- x" ]' i9 fA. 错误2 k c. g8 D$ O+ C1 K7 d2 O$ l
B. 正确
( S# k* z1 h" t, g1 ] 满分:2 分
- C* I6 z; W' T% p) }- Y8 t& c2. 抽象类不能定义对象,但可以声明抽象类的指针或引用。- x% s. u7 C( ?0 ~
A. 错误3 m9 l* E0 v0 k& i7 G- H1 O0 o
B. 正确' U2 O: h+ b* o3 [" G% M4 x
满分:2 分( l+ R9 _3 J9 |4 p
3. 类中所提供的成员函数可以直接访问该类的私有成员。- G$ Q `. g# Z6 h" L
A. 错误
7 p! T0 C Z% M( l0 Z5 R6 u% uB. 正确9 a v# q- o7 i, Q& N
满分:2 分
& y) y0 p$ [4 G8 P( ?( P" x8 ]4. 在一个类中声明了某个静态数据成员,并在类外给出其定义和初始化后,若未定义该类的对象,该静态数据成员则不存在。4 z$ i6 k% M2 [/ M* |4 ^- x* @, K* P$ D9 a
A. 错误# t) U! H, Q( ~/ e5 S, G/ [
B. 正确
# P$ }7 m% `, U5 ]/ T& G6 Z8 m2 y 满分:2 分( a" i; e1 G: t2 p7 U' I3 N h) o
5. 抽象类虽然也是一种数据类型,但它不能建立对象,只能作为基类被其他类继承。
( I& j9 H+ K. J4 h8 @ T+ O- ~A. 错误
- f" b5 @0 w$ g: e3 dB. 正确
6 K- J+ O; `2 a C 满分:2 分
2 g) J( q, ^: z, W8 R- y6. 对虚函数的调用,系统都是采用动态联编。1 f- _6 D, J3 J
A. 错误3 P( g# S+ t c3 e6 X/ x$ i% H0 [) I
B. 正确7 S) d" l3 k# U, m: `( ~' O, _4 t
满分:2 分: H6 W6 l2 _6 r7 U. \
7. C++语言类定义中默认的访问权限是public。
1 B9 @8 z, I* x; V* R8 g" CA. 错误# N" _/ @7 r7 e; Z' k" r
B. 正确
* ^& g- U& E7 w* i/ Y: l. h 满分:2 分
: t0 C7 F: h/ E8. 定义一个虚基类后,则该虚基类后继类层次中的类都需要调用虚基类的构造函数对虚基类中定义的成员变量进行初始化。
- y5 W. x# M1 m# w% FA. 错误1 }3 o8 L" U& @4 P
B. 正确
. Q5 J1 C0 \) F# Z 满分:2 分7 E" D4 J: A2 F
9. 假定要对类AB定义加号操作符重载成员函数,实现两个AB类对象的加法,并返回相加结果,则该成员函数的声明语句为: AB operator+(AB &,AB &);
1 k3 W. X' H' @: S- YA. 错误
* P- p( [7 k6 {+ H$ ~ EB. 正确0 }& q9 q$ W& ]: `* Z: t( Q
满分:2 分/ h( a$ S, W0 T! g, t
10. 在派生类对象销毁时,系统除了会自动调用派生类的析构函数,还会自动调用基类的析构函数。
( v- g$ I4 G# m9 }) OA. 错误% U0 }$ ?/ ?2 `& C5 o8 N
B. 正确
$ f; ?/ o8 B4 ` 满分:2 分) l" N$ t, ]& z1 M" W+ U
11. 在派生类构造函数的成员初始化列表中,可以包含基类构造函数的调用。
$ C: W! o; e2 M4 q& ^* aA. 错误
" _1 @6 _. c; RB. 正确
# y! G6 t$ f) y 满分:2 分- w9 l& `$ w- }2 q( {
12. 基类类型的指针可以指向其派生类对象。
1 Y) j3 G( O5 rA. 错误
1 s) I6 \5 ~/ L' n9 b% yB. 正确
2 r+ }/ s t6 I2 _) H7 e. Q 满分:2 分( Y4 w* X- f! N1 u
13. a为MyClass类对象,“static void SetRate(double r){...}”是MyClass类的静态成员函数,则执行语句“a.SetRate(0.05);”时,SetRate成员函数中的this指针指向对象a的地址。
' g, ^% F" }- ~& ZA. 错误
& F+ K* B1 s* \; g5 |B. 正确
) o1 K1 w" b, {9 B6 o 满分:2 分
5 A! c, l' d0 l% T: g( _/ x3 s14. 在C++中,允许从一个类派生出任意多个类,但不允许某个类同时从多个类派生。" v! T7 y# [, _, V
A. 错误
5 D" R* m8 T; e$ t8 v+ g' QB. 正确
$ u- w& l5 c9 Y& u, p 满分:2 分/ J& N. \5 _' b c# v
15. 在C++中,可以声明虚构造函数和虚析构函数。/ h. ?# E8 s6 M) M. E
A. 错误- ]! F" t; U0 ?/ h+ e
B. 正确
) G9 q4 g# J1 K. d k; o. K; S3 ^ 满分:2 分
0 ]8 g, E" ^2 g& |; V8 M% Q* R; E" z8 d8 E7 X$ s* f3 m7 f' a' _
谋学网(www.mouxue.com)是国内最专业的奥鹏作业资料,奥鹏离线作业资料及奥鹏毕业论文辅导型网站,主要提供奥鹏中医大、大工、东财、北语、北航、川大、南开等奥鹏作业资料辅导,致力打造中国最专业的远程教育辅导社区。
; H H" R* T" ^" l0 ` |
|