VC++程序设计期末复习题.doc

上传人:h**** 文档编号:121608 上传时间:2018-07-08 格式:DOC 页数:41 大小:270.50KB
下载 相关 举报
VC++程序设计期末复习题.doc_第1页
第1页 / 共41页
VC++程序设计期末复习题.doc_第2页
第2页 / 共41页
VC++程序设计期末复习题.doc_第3页
第3页 / 共41页
VC++程序设计期末复习题.doc_第4页
第4页 / 共41页
VC++程序设计期末复习题.doc_第5页
第5页 / 共41页
点击查看更多>>
资源描述

1、 工学院电气系 VC+程序设计期末复习题 考试采取上机方式,由计算机随机抽取 60 道选择和 40道判断题,每小题 1 分,共 100 分。该成绩占期末总成绩的 60%,剩下的 40%由课堂考勤、书面作业、上机作业等综合决定。 【下面的题目序号不重要,因时间紧张,无暇重新整理顺序,大家只需认真看题目内容即可 ,会有极个别题目答案有误,请不要理会,不考这种题 】 一、选择题 ( 1)下列的( )是引用调用。 A形参是引用,实参是变量; B形参和实参都是变量; C形参是指针,实参是地址值; D形参是数组名,实参是数组名。 ( 2)作用域运算符的功能是( ) A给定作用域的大小; 表示作用域的级别的

2、; C某个成员是属于哪个类的; 指出作用域的范围的。 ( 3)下列的各函数中,( )不是类的成员函数。 A 构造函数;析构函数;拷贝初始化构造函数;友元函数。 ( 4)下面( )不是构造函数的特征。 A构造函数可以重载; 构造函数可以设置缺省参数; 构造函数的函数名和类名相同;构造函数必须指定返回值类型。 ( 5)下述静态数据成员的特性中,( )是错误的。 A 静态数据 成员要在类体外进行初始化; B 说明静态数据成员时前边要加修饰符 static; C 静态数据成员不是所有对象所共有的; D 引用静态数据成员时,要在静态数据成员名前加 和作用域运算符。 ( 6)已知类 A 有三个公有成员:

3、void f1(int), void f2(int) 和 int a,则( )是指向类 A 成员函数的指针。 A *p; B. int A:*pc= C void( A :*pa)( int) ; . A *p; ( 7) 下列关于对象数组的描述中,( )是错的。 对象数组的数组名是一个地址常量 ; 对象数组的下标是从开始的 ; 对象数组只能赋初值,不能被赋值 ; 对象数组的数组元素是同一个类的对象 ( 8) 下列定义中,( )是定义指向类 A 的对象数组的指针。 A A *p5; A (*p) 5; (A *) p5; A *p ; ( 9)说明语句 const char *ptr;中, p

4、tr 是( )。 A指向字符常量的指针; 指向字符的常量指针; 指向字符串常量的指针; 指向字符 串的常量指针。 ( 10)关于 new 运算符的下列描述中, ( )是错的 . 使用它创建对象时要调用构造函数; 使用它创建对象数组时必须指定初始值; 它可以用来动态创建对象和对象数组; 使用它创建的对象或对象数组可以 使用运算符 delete 删除。 答: ( 1) A ( 2) C ( 3) D( 4) D( 5) C( 6) C ( 7) C ( 8) B ( 9) A ( 10) B ( 1) 派生类的对象对它的基类成员中( )是可以访问的 公有继承的保护成员; 公有继承的私有成员; 公有

5、继承的公有 成员; 私有继承的公有成员 ( 2) 下面关于派生类的描述中,( )是错的。 一个派生类可以作为另一个派生类的基类; 派生类至少有一个基类; 派生类的成员除了它自己的成员外,还包含了它的基类的成员 派生类中继承的基类成员的访问权限到派生类保持不变。 ( 3) 派生类的构造函数的成员初始化列表中,不能包含( ) 基类的构造函数调用; 派生类对象成员的初始化; 基类对象成员的初始化; 派生类中一般数据成员的初始化 ( 4) 设置虚基类的目的是( ) 减少目 标代码;消除二义性;提高运行效率; 简化程序。 ( 5) 带有虚基类的多层派生类构造函数的成员初始化列表中都要列出虚基类的构造函数

6、,这样将对虚基类的子对象初始化( ) 一次; 二次; 多次; 与虚基类下面的派生类个数有关 答案: ( 1) ( 2) D ( 3) ( 4) B ( 5) A (1) 以下保留字( )不能出现在说明虚函数原型的语句中。 A static B. operator C. void D. const . (2) 以下关于虚函数和纯虚函数的说法 中,( )是不正确的 A在派生类中虚函数可以不用关键字 virtual 说明。 B. 虚函数在派生类中可以不重定义。 C. 不能为虚函数定义缺省操作。 D. 纯虚函数在派生类中可以不重定义。 (3) 以下关于动态绑定的说法中,正确的是( ) A虚基类是动态绑

7、定的。 B. 指针是动态绑定的。 C. 所有的虚函数和纯虚函数都是动态绑定的。 D. 动态绑定与编译系统无关。 (4) 以下关于抽象类的说法中,( )是不正确的 A不可创建抽象类的实例。 B. 可以声明抽象类的引用。 C. 抽象类的派生类也是抽象类。 D. 抽象类的派生类也可以是抽象类。 (5) 以下关于抽象类的说法中,只有( )是正确的 A定义抽象类的目的是软件重用。 B. 定义抽象类是为了提高访问效率。 C. 定义抽象类是使指针的使用更灵活。 D. 抽象类提供了对类进行分类的机制。 (6) 以下关于多态性的说法中,( )是不正确的 A每个多态类的对象有一个虚表指针。 B. 虚函数调用与 t

8、his 指针无关。 C. 每个多态类的基类都有一个虚函数表。 D. 多态类的每一个派生类都有一个虚函数表。 单项选择题答案: (1) A (2) D (3) C (4) C (5) B (6) D ( 1)下列不是 C+流对象的是 ( ) A.cout B.cin C.cerr D.ostream ( 2)已知 :int w=-3,x=10,z=7 执行下面的语句的输出结果为 ( ) cout( 10?x+100:x-10) a D. x.a 109. 假定 AA 为一个类, a()为该类公有的函数成员, x 为该类的一个对象,则访问 x 对象中函数成员 a()的格式为( )。 A. x.a

9、B. x.a() C. x-a D. x-a() 110. 假定 AA 为一个类, a 为该类公有的数据成员, px 为指向该类对象的一个指针,则访问 px 所指对象中数据成员 a 的格式为( )。 A. px(a) B. pxa C. px-a D. px.a 111. 假定 AA 为一个类, a 为该类私有的数据成员, GetValue()为该类公有函数成员,它返回 a 的值, x 为该类的一个对象,则访问 x 对象中数据成员 a 的格式为( )。 A. x.a B. x.a() C. x-GetValue() D. x.GetValue() 112. 假定 AA 为一个类, int a(

10、)为该类的一个成员函数,若该成员函数在类定义体外定 义,则函数头为( )。 A. int AA:a() B. int AA:a() C. AA:a() D. AA:int a() 113. 假定 AA 为一个类, a 为该类公有的数据成员,若要在该类的一个成员函数中访问它,则书写格式为( )。 A. a B. AA:a C. a() D. AA:a() 114. 若需要把一个类外定义的成员函数指明为内联函数,则必须把关键字( )放在函数原型或函数头的前面。 A. in B. inline C. inLine D. InLiner 115. 在多文件结构的程序中,通常把类的定义单独存放于( )中

11、。 A. 主文件 B. 实现文件 C. 库文件 D. 头文件 116. 在多文件结构的程序中,通常把类中所有非内联函数的定义单独存放于( )中。 A. 主文件 B. 实现文件 C. 库文 件 D. 头文件 117. 在多文件结构的程序中,通常把含有 main()函数的文件称为( )。 A. 主文件 B. 实现文件 C. 程序文件 D. 头文件 118. 一个 C+程序文件的扩展名为( )。 A. .h B. .c C. .cpp D. .cp 119. 在 C+程序中使用的 cin 标识符是系统类库中定义的( )类中的一个对象。 A. istream B. ostream C. iostrea

12、m D. fstream 120. 在 C+程序中使用的 cout 标识符是系统类库中定义的( )类中的一个对象。 A. istream B. ostream C. iostream D. fstream 121. 假定 AA 是一个类, abc 是该类的一个成员函数,则参数表中隐含的第一个参数的类型为( )。 A. int B. char C. AA D. AA* 122. 假定 AA 是一个类, abc 是该类的一个成员函数,则参数表中隐含的第一个参数为( )。 A. abc B. *this C. this D. this”是该类中一个成员函数的原型,若该函数存在对 *this 赋值的语

13、句,当用x.abc()调用该成员函数后, x 的值( )。 A. 已经被改变 B. 可能被改变 C. 不变 D.不受函数调用的影响 124. 假定 AA 是一个类,“ AA* abc()const;”是该类中一个成员函数的原型,若该函数返回 this 值,当用 x.abc()调用该成员函数后, x 的值( )。 A. 已经被改变 B. 可能被改变 C. 不变 D. 受到函数调用的影响 125. 类中定义的成员默认为( )访问属性。 A. public B. private C. protected D. friend 126. 结构中定义的成员默认为( )访问属性。 A. public B.

14、private C. protected D. friend 127. 当类中一个字符指针成员指向具有 n 个字节的存储空间时,它所能存储字符串的最大长度为 ( )。 A. n B. n+1 C. n-1 D. n-2 128. 在一个用数组实现的队 列类中,假定数组长度为 MS,队首元素位置为 first,队列长度为 length,则队尾(即最后一个)元素的位置为 ( )。 A. length+1 B. first+length C. (first+length-1)%MS D. (first+length)%MS 129. 在一个用数组实现的队列类中,假定数组长度为 MS,队首元素位置为

15、first,队列长度为 length,则队尾的后一个位置为 ( )。 A. length+1 B. first+length C. (first+length-1)%MS D. (first+length)%MS 130. 在一个用数组实现的队列类中,假定数组长度为 MS,队首元素位置为 first,队列长度为 length,则队首的后一个位置为 ( )。 A. first+1 B. (first+1)%MS C. (first-1)%MS D. (first+length)%MS 131. 在一个用链表实现的队列类中,假定每个结点包含的值域用 elem 表示,包含的指针域用 next 表示,

16、链队的队首指针用 elemHead 表示,队尾指针用 elemTail 表示,若链队非空,则进行插入时必须把新结点的地址赋给 ( )。 A. elemHead B. elemTail C. elemHead-next 和 elemHead D. elemTail-next 和 elemTail 132. 在一个用链表实现的队列类中,假定每个结点包含的值域用 elem 表示,包含的指针域用 next 表示,链队的队首指针用 elemHead 表示,队尾指针用 elemTail 表示,若链队为空,则进行插入时必须把新结点的地址赋给 ( )。 A. elemHead B. elemTail C. e

17、lemHead 和 elemTail D. elemHead 或 elemTail 133. 队列具有( )的操作特性。 A. 先进先出 B. 先进后出 C. 进出无序 D. 进出任意 134. 栈具有( )的操作特性。 A. 先进先出 B. 先进后出 C. 进出无序 D. 进出任意 135. 对于一个类的构造函数,其函数名与类名 ( )。 A. 完全相同 B. 基本相同 C. 不相同 D. 无关系 136. 对于一个类的析构函数,其函数名与类名 ( )。 A. 完全相同 B. 完全不同 C. 只相差一个字符 D. 无关系 137. 类的构造函数是在定义该类的一个 ( )时被自动调用执行的。

18、A. 成员函数 B. 数据成员 C. 对象 D. 友元函数 138. 类的析构函数是一个对象被 ( )时自动调用的。 A. 建立 B. 撤消 C. 赋值 D. 引用 139. 一个类的构造函数通常被定义为 该类的 ( )成员。 A. 公用 B. 保护 C. 私有 D. 友元 140. 一个类的析构函数通常被定义为该类的 ( )成员。 A. 私有 B. 保护 C. 公用 D. 友元 141. 假定 AB 为一个类,则执行 “ AB x;” 语句时将自动调用该类的 ( )。 A. 带参构造函数 B. 无参构造函数 C. 拷贝构造函数 D. 赋值重载函数 142. 假定 AB 为一个类,则执行 “

19、AB x(a,5);” 语句时将自动调用该类的 ( )。 A. 带参构造函数 B. 无参构造函数 C. 拷贝构造函数 D. 赋值重载函数 143. 假定 AB 为一个类,则执行 “ AB *s=new AB(a,5);” 语句时得到的一个动态对象为 _。 A. s B. s-a C. s.a D. *s 144. 假定 AB 为一个类,则执行 “ AB r1=r2;” 语句时将自动调用该类 的 ( )。 A. 无参构造函数 B. 带参构造函数 C. 赋值重载函数 D. 拷贝构造函数 145. 若需要使类中的一个指针成员指向一块动态存储空间,则通常在 ( )函数中完成。 A. 析构 B. 构造

20、C. 任一成员 D. 友元 146. 当类中的一个整型指针成员指向一块具有 n*sizeof(int)大小的存储空间时,它最多能够存储 ( )个整数。 A. n B. n+1 C. n-1 D. 1 147. 假定一个类的构造函数为 “ A(int aa, int bb) a=aa; b=aa*bb;” ,则执行 “ A x(4,5);” 语句后, x.a和 x.b 的值分别为 ( )。 A. 4 和 5 B. 5 和 4 C. 4 和 20 D. 20 和 5 148. 假定一个类的构造函数为 “ A(int aa=1, int bb=0) a=aa; b=bb;” ,则执行 “ A x(4

21、);” 语句后, x.a和 x.b 的值分别为 ( )。 A. 1 和 0 B. 1 和 4 C. 4 和 1 D. 4 和 0 149. 假定 AB 为一个类,则 ( )为该类的拷贝构造函数的原型说明。 A. AB(AB x); B. AB(AB C. void AB(AB D. AB(int x); 150. 假定一个类的构造函数为 “ B(int ax, int bx): a(ax), b(bx) ” ,执行 “ B x(1,2),y(3,4);x=y;” 语句序列后 x.a 的值为 ( )。 A. 1 B. 2 C. 3 D. 4 151. 假定一个类 AB 只含有一个整型数据成员 a

22、,当用户不定义任何构造函数时,系统为该类定义的无参构造函数为 ( )。 A. AB() a=0; B. AB(int aa=0): a(aa) C. AB(int aa): a(aa) D. AB() 152. 假 定一个类 AB 只含有一个整型数据成员 a,用户为该类定义的带参构造函数可以为 ( )。 A. AB() B. AB(): a(0) C. AB(int aa=0) a=aa; D. AB(int aa) 153. 对于任一个类,用户所能定义的构造函数的个数至多为 ( )。 A. 0 B. 1 C. 2 D. 任意个 154. 对于任一个类,用户所 能定义的析构函数的个数至多为 (

23、 )。 A. 0 B. 1 C. 2 D. 任意个 155. 假定 AB 为一个类,则执行 “ AB *px=new ABn;” 语句时将 ( )。 A. 动态分配一个数组 B. 动态分配一个对象 C. 静态分配一个数组 D. 静态分配一个对象 156. 设 px 是指向一个类对象的指针变量,则执行 “ delete px;” 语句时,将自动调用该类的 ( )。 A. 无参构造函数 B. 带参构造函数 C. 析构函数 D. 拷贝构造函数 157. 当一个类对象离开它的作用域时,系统自动调用该类的 ( )。 A. 无参构造函数 B. 带参构造函数 C. 拷贝构造函数 D. 析构函数 158. 假

24、定一个类对象数组为 An,当离开它定义的作用域时,系统自动调用该类析构函数的次数为 ( )。 A. 0 B. 1 C. n D. n-1 159. 假定 AB 为一个类,则执行 “ AB a10;” 语句时调用该类无参构造函数的次数为 ( )。 A. 0 B. 1 C. 9 D. 10 160. 假定 AB 为一个类,则执行 “ AB *px=new ABn;” 语句时调用该类无参构造函数的次数为 ( )。 A. n B. n-1 C. 1 D. 0 161. 假定 AB 为一个类,则执行 “ AB a, b(3), *p;” 语句时共调用 该类构造函数的次数为 ( )。 A. 2 B. 3

25、C. 4 D. 5 162. 假定 AB 为一个类,则执行 “ AB a(2), b3, *p4;” 语句时共调用该类构造函数的次数为 ( )。 A. 3 B. 4 C. 5 D. 9 163. 假定 AB 为一个类,则执行“ AB a, b(2), c3, *p=”语句时共调用该类无参构造函数的次数为 ( )。 A. 5 B. 6 C. 3 D. 4 164. 假定 AB 为一个类,则执行“ AB *p=new AB(1,2);”语句时共调用该类构造函数的次数为 ( )。 A. 0 B. 1 C. 2 D. 3 165. 假定 AB 为一个类, px 为指向该类的一个含有 n 个对象的动态数

26、组的指针,则执行“ delete px;”语句时共调用该类析构函数的次数为 ( )。 A. 0 B. 1 C. n D. n+1 166. 对类对象成员的初始化是通过构造函数中给出的 ( )实现的。 A. 函数体 B. 初始化表 C. 参数表 D. 初始化表或函数体 167. 对类中常量成员的初始化是通过构造函数中给出的 ( )实现的。 A. 函数体 B. 参数表 C. 初始化表 D. 初始化表或函数体 168. 对类中引用成员的初始化是通过构造函数中给出的 ( )实现的。 A. 函数体 B. 参数表 C. 初始化表 D. 初始化表或函数体 169. 类的构造函数可以带有 ( )个参数。 A.

27、 0 B. 1 C. 2 D. 任意 170. 类的析构函数可以带有 ( )个参数。 A. 0 B. 1 C. 2 D. 任意 171. 一个类的静态数据成员所表示属性 ( )。 A. 是类的或对象的 属性 B. 只是对象的属性 C. 只是类的属性 D. 类和友元的属性 172. 类的静态成员的访问控制( )。 A. 只允许被定义为 private B. 只允许被定义为 private 或 protected C. 只允许被定义为 public D. 可允许被定义为 private、 protected 或 public 173. 静态成员函数对类的数据成员访问( )。 A. 是不允许的 B.

28、 只允许是静态数据成员 C. 只允许是非静态数据成员 D. 可允许是静态数据成员或非静态数据成员 174. 被非静态成员函数访问的类的数据成员 ( )。 A. 可以是非静态数据成员或静态数据成员 B. 不可能是类的静态数据成员 C. 只能是类的非静态数据成员 D. 只能是类的静态数据成员 175. 静态数据成员的初始化 是在( )中进行的。 A. 构造函数 B. 任何成员函数 C. 所属类 D. 全局区 176. 当将一个类 A 或函数 f()说明为另一个类 B 的友元后,类 A 或函数 f()能够直接访问类 B的( )。 A. 只能是公有成员 B. 只能是保护成员 C. 只能是除私有成员之外

29、的任何成员 D. 具有任何权限的成员 177. 引入友元的主要目的是为了( )。 A. 增强数据安全性 B. 提高程序的可靠性 C. 提高程序的效率和灵活性 D. 保证类的封装性 178. 一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明( )。 A. 需加上类域的限定 B. 不需加上类域的限定 C. 类域的限定可加可不加 D. 不需要任何限定 179. 一个类的友元不是 该类的成员,与该类的关系密切,所以它( )。 A. 有 this 指针,有默认操作的对象 B. 没有 this 指针,可以有默认操作的对象 C. 有 this 指针,不能执行默认操作 D. 没有 this 指针,

30、也就没有默认操作的对象 180. 在重载一个运算符时,其参数表中没有任何参数,这表明该运算符是( )。 A. 作为友元函数重载的 1 元运算符 B. 作为成员函数重载的 1 元运算符 C. 作为友元函数重载的 2 元运算符 D. 作为成员函数重载的 2 元运算符 181. 在成员函数中进行双目运算符重载时,其参数表中应带有( )个参数。 A. 0 B. 1 C. 2 D. 3 182. 双目运算符重载为普通函数时,其参数表中应带有( )个参数。 A. 0 B. 1 C. 2 D. 3 183. 如果表达式 a+b 中的“ +”是作为成员函数重载的运算符,若采用运 算符函数调用格式,则可表示为(

31、 )。 A. a.operator+(b) B. b.operator+(a) C. operator+(a,b) D. operator(a+b) 184. 如果表达式 a=b 中的“ =”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator=(b) B. b.operator=(a) C. operator=(a,b) D. operator=(b,a) 185. 如果表达式 a+中的“ +”是作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator+() B. operator+(a) C. ope

32、rator+(a,1) D. operator+(1,a) 186. 如果表达式 +a 中的“ +”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为( )。 A. a.operator+(1) B. operator+(a) C. operator+(a,1) D. a.operator+() 187. 关于运算符重载,下列说法正确的是( )。 A. 重载时,运算符的优先级可以改变。 B. 重载时,运算符的结合性可以改变。 C. 重载时,运算符的功能可以改变。 D. 重载时,运算符的操作数个数可以改变。 188. 关于运算符重载,下列说法正 确的是( )。 A. 所有的运算符都

33、可以重载。 B. 通过重载,可以使运算符应用于自定义的数据类型。 C. 通过重载,可以创造原来没有的运算符。 D. 通过重载,可以改变运算符的优先级。 189. 一个程序中数组 a 和变量 k 定义为“ int a510,k;”,且程序中包含有语句“ a(2,5)=+k*3;”,则此语句中肯定属于重载操作符的是( )。 A. ( ) B. = C. + D. * 190. 假定 K 是一个类名,并有定义“ K k; int j;”,已知 K 中重载了操作符 ( ),且语句“ j=k(3);”和“ k(5)=99;”都能顺利执行,说明该操作符函数的原形只可能是( )。 A. K operator

34、 ( ) (int); B. int operator ( )(int C. int D. K 191. 假定 M 是一个类名 ,且 M 中重载了操作符 =,可以实现 M 对象间的连续赋值,如“ m1=m2=m3;”。重载操作符=的函数原型最好是( )。 A. int operaotor=(M); B. int operator=(M C. M operator=(M D. M 192. 下面是重载双目运算符 +的普通函数原形,其中最符合 +原来含义的是( )。 A. Value operator+(Value, Value); B. Value operator+(Value,int); C

35、. Value D. Value 193. 下面是重载双目运算符 -的成员函数原形,其中最符合 -原来含义的是( )。 A. Value Value:operator-(Value); B. Value Value:operator-(int); C. Value D. Value 194. 在重载一运算符时,若运算符函数的形参表中没有参数,则不可能的情况是( )。 A. 该运算符是一个单目运算符。 B. 该运算符函数有一个隐含的参数 this。 C. 该运算符函数是类的成员函数。 D. 该运算符函数是类的友元函数 。 195. 关于插入运算符 的重载,下列说法不正确的是( )。 A. 运算符

36、函数的返回值类型是 ostream & 。 B. 重载的运算符必须定义为类的成员函数。 C. 运算符函数的第一个参数的类型是 ostream & 。 D. 运算符函数有两个参数。 196. 从一个基类派生出的各个类的对象之间 ( )。 A. 共享所有数据成员,每个对象还包含基类的所有属性 B. 共享部分数据成员,每个对 象还包含基类的所有属性 C. 不共享任何数据成员,但每个对象还包含基类的所有属性 D. 共享部分数据成员和函数成员 197. 如果是类 B 在类 A 的基础上构造,那么,就称( )。 A. 类 A 为基类或父类,类 B 为超类或子类 B. 类 A 为基类、父类或超类,类 B 为

37、派生类或子类 C. 类 A 为派生类,类 B 为基类 D. 类 A 为派生类或子类,类 B 为基类、父类或超类 198. C+的继承性允许派生类继承基类的( )。 A. 部分特性,并允许增加新的特性或重定义基类的特性 B. 部分特性,但不允许增加新的特性或重定义基类的特性 C. 所有特性,并允许增加新的特性或重定义基类的特性 D. 所有特性,但不允许增加新的特性或重定义基类的特性 199. 派生类的成员函数可以直接访问基类的( )成员。 A. 所有 B. 公有和保护 C. 保护和私有 D. 私有 200. 对于公有继承,基类的公 有和保护成员在派生类中将 ( )成员。 A. 全部变成公有 B.

38、 全部变成保护 C. 全部变成私有 D. 仍然相应保持为公有和保护 201. 对于公有继承,基类中的私有成员在派生类中将 ( )。 A. 能够直接使用成员名访问 B. 能够通过成员运算符访问 C. 仍然是基类的私有成员 D. 变为派生类的私有成员 202. 当保护继承 时,基类的( )在派生类中成为保护成员,在类作用域外不能够通过派生类的对象来直接访问该成员。 A. 任何成员 B.公有成员和保护成员 C. 保护成员和私有成员 D.私有成员 203. 在定义一个派生类时,若不使用保留字显式地规定采用何种继承方式,则默认为( )方式。 A. 私有继承 B. 非私有继承 C. 保护继承 D. 公有继

39、承 204. 建立包含有类对象成员的派生类对象时,自动调用构造函数的执行顺序依次为( )的构造函数。 A. 自己所属类、对象成员所属类、基类 B. 对象成员所属类、基类、自己所属类 C. 基类、对象成员所属类、自己所属类 D. 基类、自己所属类、对象成员所属类 205. 当派生类中有和基类一样名字的成员时,一般来说, ( )。 A. 将产生二义性 B. 派生类的同名成员将覆盖基类的成员 C. 是不能允许的 D. 基类的同名成员将覆盖派生类的成员 206. C+中的虚基类机制可以保证: ( )。 A. 限定基类只通过一条路径派生出派生类 B. 允许基类通过多条路径派生出派生类,派生类也就能多次继

40、承该基类 C. 当一个类多次间接从基类派生以后,派生类对象能保留多份间接基类的成员 D. 当一个类多次间接从基类派生以后,其基类只被一次继承 207. 下列对派生类的描述中错误的说法是: ( )。 A. 派生类至少有一个基类 B. 派生类可作为另一个派生类的基类 C. 派生类除了包含它直接定义的成员外,还包含其基类的成员 D. 派生类所继承的基类成员的访问权限保持不变 208. 派生类的对象对其基类中( )可直接访问 。 A. 公有继承的公有成员 B. 公有继承的私有成员 C. 公有继承的保护成员 D. 私有继承的公有成员 答 案: 【如没有该题,请忽略该答案】 94. B 95. D 96.

41、 C 97. A 98. B. 99. C 100. D 101. A 102. B 103. B 104. C 105. D 106. B 107. A 108. D 109. B 110. C 111. D 112. A 113. A 114. B 115. D 116. B 117. A 118. C 119. A 120. B 121. D 122. C 123. A 124. C 125. B 126. A 127. C 128. C 129. D 130. B 131. D 132. C 133. A 134. B 135. A 136. C 137. C 138. B 139. A 140. C 141. B 142. A 143. D 144. D 145. B 146. A 147. C 148. D 149. B 150. C 151. D 152. C 153. D 154. B 155. A 1

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 复习参考

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。