1、1 面向对象程序设计 期末复习题 2 一、单选题 1. 能作为 C+程序的基本单位是 ( c )。 A. 字符 B. 语句 C. 函数 D. 源程序文件 2. 存储以下数据,占用存储字节最多的是( d )。 A. 0 B. 0 C. “ 0” D. 0.0 3. 设 ” int a=15,b=26;” ,则 ” couta D. x.a 29. 109. 假定 AA 为一个类, a()为该类公有的函数成员, x 为该类的一个对象,则访问x 对象中函数成员 a()的格式为( b )。 A. x.a B. x.a() C. x-a D. x-a() 30. 110. 假定 AA 为一个类, a 为
2、该类公有的数据成员, px 为指向该类对象的一个指针,则访问 px 所指对象中数据成员 a 的格式为( c )。 A. px(a) B. pxa C. px-a D. px.a 31. 111. 假定 AA 为一个类, a 为该类私有的数据成员, GetValue()为该类公有函数成员,它返回 a的值, x为该类的一个对象,则访问 x对象中数据成员 a的格式 为( d )。 A. x.a B. x.a() C. x-GetValue() D. x.GetValue() 32. 112. 假定 AA 为一个类, int a()为该类的一个成员函数,若该成员函数在类定义体外定义,则函数头为( a
3、)。 A. int AA:a() B. int AA:a() C. AA:a() D. AA:int a() 33. 113. 假定 AA 为一个类, a 为该类公有的 数据成员,若要在该类的一个成员函数中访问它,则书写格式为( a )。 A. a B. AA:a C. a() D. AA:a() 34. 114. 若需要把一个类外定义的成员函数指明为内联函数,则必须把关键字( b )放在函数原型或函数头的前面。 A. in B. inline C. inLine D. InLiner 35. 115. 在多文件结构的程序中,通常把类的定义单独存放于( d )中。 A. 主文件 B. 实现文件
4、 C. 库文件 D. 头文件 36. 116. 在多文件结构的程序中,通常把类中所有非内联函数的定义单独存放于( b )中。 A. 主文件 B. 实现文件 C. 库文件 D. 头文件 37. 117. 在多文件结构的程序中,通常把含有 main()函数的文件称为( a )。 A. 主文件 B. 实现文件 C. 程序文件 D. 头文件 38. 118. 一个 C+程序文件的扩展名为( c )。 A. .h B. .c C. .cpp D. .cp 39. 119. 在 C+程序中使用的 cin 标识符是系统类库中定义的( a )类中的一个对象。 A. istream B. ostream C.
5、iostream D. fstream 40. 120. 在 C+程序中使用的 cout 标识符是系统类库中定义的( b )类中的一个对象。 A. istream B. ostream C. iostream D. fstream 41. 121. 假定 AA 是一个类, abc 是该类的一个成员函数,则参数表中隐含的第一个参数的类型为( d )。 A. int B. char C. AA D. AA* 42. 122. 假定 AA 是一个类, abc 是该类的一个成员函数,则参数表中隐含的第一个参数为( c )。 A. abc B. *this C. this D. this”是该类中一个成
6、员函数的原型,若该函数存在对 *this 赋值的语句,当用 x.abc()调用该成员函数后, x 的值( a )。 A. 已经被改变 B. 可能被改变 C. 不变 D.不受函数调用的影响 44. 124. 假定 AA 是一个类,“ AA* abc()const;”是该类中一个成员函数的原型,若该函数返回 this 值,当用 x.abc()调用该成员函数后, x 的 值( c )。 A. 已经被改变 B. 可能被改变 C. 不变 D. 受到函数调用的影响 45. 125. 类中定义的成员默认为( b )访问属性。 A. public B. private C. protected D. frie
7、nd 46. 126. 结构中定义的成员默认为( a )访问属性。 A. public B. private C. protected D. friend 47. 127. 当类中一个字符指针成员指向具有 n 个字节的存储空间时,它所能存储字符串的最大长度为 ( c )。 A. n B. n+1 C. n-1 D. n-2 48. 135. 对于一个类的构造函数,其函数名与类名 ( a )。 A. 完全相同 B. 基本相同 C. 不相同 D. 无关系 49. 136. 对于一个类的析构函数,其函数名与类名 ( c )。 A. 完全相同 B. 完全不同 C. 只相差一个字符 D. 无关系 50.
8、 137. 类的构造函数是在定义该类的一个 ( c )时被自动调用执行的。 A. 成员函数 B. 数据成员 C. 对象 D. 友元函数 51. 138. 类的析构函数是一个对象被 ( b )时自动调用的。 A. 建立 B. 撤消 C. 赋值 D. 引用 52. 139. 一个类的构造函数通常被定义为 该类的 ( a )成员。 A. 公用 B. 保护 C. 私有 D. 友元 53. 140. 一个类的析构函数通常被定义为该类的 ( c )成员。 A. 私有 B. 保护 C. 公用 D. 友元 54. 141. 假定 AB 为一个类,则执行 “ AB x;” 语句时将自动调用该类的 ( b )。
9、A. 带参构造函数 B. 无参构造函数 C. 拷贝构造函数 D. 赋值重载函数 55. 142. 假 定 AB 为一个类,则执行 “ AB x(a,5);” 语句时将自动调用该类的( a )。 A. 带参构造函数 B. 无参构造函数 C. 拷贝构造函数 D. 赋值重载函数 56. 143. 假定 AB 为一个类,则执行 “ AB *s=new AB(a,5);” 语句时得到的一个动态对象为 _d_。 A. s B. s-a C. s.a D. *s 57. 144. 假定 AB 为一个类,则执行 “ AB r1=r2;” 语句时将自动 调用该类的( d )。 A. 无参构造函数 B. 带参构造
10、函数 C. 赋值重载函数 D. 拷贝构造函数 58. 145. 若需要使类中的一个指针成员指向一块动态存储空间,则通常在 ( b )函数中完成。 A. 析构 B. 构造 C. 任一成员 D. 友元 59. 146. 当类中的一个整型指针成员指向一块具有 n*sizeof(int)大小的存储空间时,它最多能够存储 ( a )个整数。 A. n B. n+1 C. n-1 D. 1 6 60. 147. 假定一个类的构造函数为 “ A(int aa, int bb) a=aa; b=aa*bb;” ,则执行 “ A x(4,5);” 语句后, x.a 和 x.b 的值分别为 ( c )。 A. 4
11、 和 5 B. 5 和 4 C. 4 和 20 D. 20 和 5 61. 148. 假定一个类的构造函数为 “ A(int aa=1, int bb=0) a=aa; b=bb;” ,则执行 “ A x(4);” 语句后 , x.a 和 x.b 的值分别为 ( d )。 A. 1 和 0 B. 1 和 4 C. 4 和 1 D. 4 和 0 62. 149. 假定 AB 为一个类,则 ( b )为该类的拷贝构造函数的原型说明。 A. AB(AB x); B. AB(AB C. void AB(AB D. AB(int x); 63. 150. 假定一个类的构造函数为 “ B(int ax,
12、int bx): a(ax), b(bx) ” ,执行 “ B x(1,2),y(3,4);x=y;” 语句序列后 x.a 的值为 ( c )。 A. 1 B. 2 C. 3 D. 4 64. 151. 假定一个类 AB 只含有一个整型数据成员 a,当用户不定义任何构造函数时,系统为该类定义的无参构造函数为 ( d )。 A. AB() a=0; B. AB(int aa=0): a(aa) C. AB(int aa): a(aa) D. AB() 39. 假定一个类 AB 只含有一个整型数据成员 a,用户为该类定义的带参构造函数可以为( c )。 A. AB() B. AB(): a(0)
13、C. AB(int aa=0) a=aa; D. AB(int aa) 65. 153. 对于任一个类,用户所能定义的构造函数的个数至多为 ( d )。 A. 0 B. 1 C. 2 D. 任意个 66. 154. 对 于任一个类,用户所能定义的析构函数的个数至多为 ( b )。 A. 0 B. 1 C. 2 D. 任意个 67. 155. 假定 AB 为一个类,则执行 “ AB *px=new ABn;” 语句时将 ( a )。 A. 动态分配一个数组 B. 动态分配一个对象 C. 静态分配一个数组 D. 静态分配一个对象 68. 156. 设 px 是指向一个类对象的指针变量,则执行 “
14、delete px;” 语句时,将自动调用 该类的 ( c )。 A. 无参构造函数 B. 带参构造函数 C. 析构函数 D. 拷贝构造函数 69. 157. 当一个类对象离开它的作用域时,系统自动调用该类的 ( d )。 A. 无参构造函数 B. 带参构造函数 C. 拷贝构造函数 D. 析构函数 70. 158. 假定一个类对象数组为 An,当离开它定义的作用域时,系统自动调用该类析构函数的次数为 ( c )。 A. 0 B. 1 C. n D. n-1 71. 159. 假定 AB 为一个类,则执行 “ AB a10;” 语句时调用该类无参构造函数的次数为 ( d )。 A. 0 B. 1
15、 C. 9 D. 10 72. 160. 假定 AB 为一个类,则执行 “ AB *px=new ABn;” 语句时调用该类无参构造函数的次数为 ( a )。 A. n B. n-1 C. 1 D. 0 73. 161. 假定 AB 为一个类,则执行 “ AB a, b(3), *p;” 语句时共调用该类构造函数的次数为 ( a )。 A. 2 B. 3 C. 4 D. 5 74. 162. 假定 AB 为一个类,则执行 “ AB a(2), b3, *p4;” 语句时共调用该类构造函数的次数为 ( b )。 7 A. 3 B. 4 C. 5 D. 9 75. 163. 假定 AB 为一个类,
16、则执行“ AB a, b(2), c3, *p=”语句时共调用该类无参构造函数的次数为 ( d )。 A. 5 B. 6 C. 3 D. 4 76. 164. 假定 AB 为一个类,则执行“ AB *p=new AB(1,2);”语句时共调用该类构造函数的次数为 ( b )。 A. 0 B. 1 C. 2 D. 3 77. 165. 假定 AB为一个类, px为指向该类的一个含有 n个对象的动态数组的指针,则执行“ delete px;”语句时共调用该类析构函数的次数为 ( c )。 A. 0 B. 1 C. n D. n+1 78. 166. 对类对象成员的初始化是通过构造函数中给出的 (
17、b )实现的。 A. 函数体 B. 初始化表 C. 参数表 D. 初始化表或函数体 79. 167. 对类中常量成员的初始化是通过构造函数中给出的 ( c )实现的。 A. 函数体 B. 参数表 C. 初始化表 D. 初始化表或函数体 80. 169. 类的构造函数可以带有 ( c )个参数。 A. 0 B. 1 C. 2 D. 任意 81. 170. 类的析构函数可以带有 ( a )个参数。 A. 0 B. 1 C. 2 D. 任意 82. 171. 一个类的静态数据成员所表示属性 ( c )。 A. 是类的或对象的属性 B. 只是对象的属性 C. 只是类的属性 D. 类和友元的属性 83.
18、 172. 类的静态成员的访问控制( d )。 A. 只允许被定义为 private B. 只允许被定义为 private 或 protected C. 只允许被定义为 public D. 可允许被定义为 private、 protected 或 public 84. 173. 静态成员函数对类的数据成员访问( b )。 A. 是不允许的 B. 只允许是静态数据成员 C. 只允许是非静态 数据成员 D. 可允许是静态数据成员或非静态数据成员 85. 174. 被非静态成员函数访问的类的数据成员 ( a )。 A. 可以是非静态数据成员或静态数据成员 B. 不可能是类的静态数据成员 C. 只能是
19、类的非静态数据成员 D. 只能是类的静态数据成员 86. 175. 静态数据成员的初始化是在( d )中进行的。 A. 构造函数 B. 任何成员函数 C. 所属类 D. 全局区 87. 178. 一个类的成员函数也可以成为另一个类的友元函数,这时的友元说明( a )。 A. 需加上类域的限定 B. 不需加上类域的限定 C. 类域的限定可加可不加 D. 不需要任何限定 88. 179. 一个类的友元不是该类的成员,与该类的关系密切,所以它( d )。 A. 有 this 指针,有默认操作的对象 B. 没有 this 指针,可以 有默认操作的对象 C. 有 this 指针,不能执行默认操作 D.
20、没有 this 指针,也就没有默认操作的对象 8 89. 180. 在重载一个运算符时,其参数表中没有任何参数,这表明该运算符是( b )。 A. 作为友元函数重载的 1 元运算符 B. 作为成员函数重载的 1 元运算符 C. 作为友元函数重载的 2 元运算符 D. 作为成员函数重载的 2 元运算符 90. 181. 在成员函数中进行双目运算符重载时,其参数表中应带有( b )个参数。 A. 0 B. 1 C. 2 D. 3 91. 182. 双目运算符重载为普通函数时,其参数表中应带有( c )个参数。 A. 0 B. 1 C. 2 D. 3 92. 185. 如果表达式 a+中的“ +”是
21、作为普通函数重载的运算符,若采用运算符函数调用格式,则可表示为( c )。 A. a.operator+() B. operator+(a) C. operator+(a,1) D. operator+(1,a) 93. 186. 如果表达式 +a 中的“ +”是作为成员函数重载的运算符,若采用运算符函数调用格式,则可表示为( d )。 A. a.operator+(1) B. operator+(a) C. operator+(a,1) D. a.operator+() 94. 187. 关于运算符重载,下列说法正确的是( c )。 A. 重载时,运算符的 优先级可以改变。 B. 重载时,运
22、算符的结合性可以改变。 C. 重载时,运算符的功能可以改变。 D. 重载时,运算符的操作数个数可以改变。 95. 189. 一个程序中数组 a 和变量 k 定义为“ int a510,k;”,且程序中包含有语句“ a(2,5)=+k*3;”,则此语句中肯定属于重载操作符的是( a )。 A. ( ) B. = C. + D. * 96. 190. 假定 K 是一个类名,并有定义“ K k; int j;”,已知 K 中重载了操作符 ( ),且语句“ j=k(3);”和“ k(5)=99;”都能顺利执行,说明该操作符函数的原形只可能是( c )。 A. K operator ( ) (int);
23、 B. int operator ( )(int C. int D. K 97. 195. 关于插入运算符 T cubin(T n)return n*n*n ; _。 9. 97. 如果一个函数中有多个默认参数,则默认参数必须全部 处在形参表的 _右面_部分。 10. 132. 若要把整型变量 y定义为 x的引用,则所使用的定义语句为 _ int y=x;_。 11. 133. 若 y 是 x 的引用,则对 y 的操作就是对 _x_的操作。 12. 134. 若 y 是 x 的引用,则 y 和 x的值 _相同 _,即为变量 _x_的地址。 13. 135. 执行 int p=new int 操
24、作得到的一个动态分配的整型对象为 _*p _。 14. 137. 执行 char *p=new char( a )操作后, p 所指向的数据对象的值为 _ a_。 15. 138. 执行 new charmn操作 时的返回值的类型为 _char(*)n_。 16. 139. 执行 _delete p_操作将释放由 p 所指向的动态分配的数据空间。 17. 149. 已知变量 a 定义为“ int a=5;”,要使 ra 成为 a 的引用,则 ra 应定义为 _ int ra=a;_。 18. 155. 对象将其大部分实现细节隐藏起来,这种机制称为 _封装 _。 19. 156. 基类和派生类的
25、关系称为 _继承 _。 20. 160. 如果一个派生类的基类不止一个,则这种继承称为 _多继承 _。 21. 162. C+支持两种多态性: _编译 _时的多态性和 _运行 _时的多态性。 22. 163. 在 C+中,编译时的多态性是通过 _重载 _实现的,而运行时的多态性则是通过 _虚函数 _实现的。 23. 172. 若在类的定义体中给出了一个成员函数的完整定义,则该函数属于 _内联 _函数。 24. 173. 若在类的定义体中只给出了一个成员函数的原型,则在类外给出完整定义时,其函数名前必须加上 _类名 _和两个冒号分隔符。 25. 175. 若要把类外定义的成员函数规定为内联函数,
26、则必须把 _inline_关键字放到函数原型或函数头的前面。 26. 176. 把一个类的定义体和所有成员函数的定义体所构成的程序范围叫做该类的_作用域 _。 27. 177. 假定 AA 是一个类,“ AA* abc();”是该类中一个成员函数的原型,则在类外定义时的函数头为 _ AA* AA:abc()_。 28. 178.成员函数的参数表在类作用域中,成员函数的返回值类型 _不在 _类作用域中。 29. 179. 为了避免在调用成员函数时修改对象中的任何数据成员,则应在定义该成员函数时,在函数头的后面加上 _const_关键字。 30. 180. 若只需要通过一个成员函数读取数据成员的值,而不需要修改它,则应在函数头的后面加上 _const_关键字。 31. 183. 内联函数的定义模块与 _类 定义 _模块必须放在同一个文件中。 32. 184假定 AA 是一个类,“ AA* abc()const;”是该类中一个成员函数的原型,在该函数体中(能够 /不能够) _不能够 _向 *this 或其成员赋值。 33. 201一个类的 _构造 _函数实现对该类对象的初始化功能。 34. 202一个类的 _析构 _函数通常用于实现释放该类对象中指针成员所指向的动态存储空间的任务。