ImageVerifierCode 换一换
格式:DOCX , 页数:81 ,大小:56.28KB ,
资源ID:7173335      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-7173335.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(《C++程序设计》期末复习题要点文档格式.docx)为本站会员(b****4)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

《C++程序设计》期末复习题要点文档格式.docx

1、a; C void(A :*pa)(int);. A *p;(7)下列关于对象数组的描述中,( C )是错的。对象数组的数组名是一个地址常量;对象数组的下标是从开始的;对象数组只能赋初值,不能被赋值;对象数组的数组元素是同一个类的对象(8)下列定义中,( B)是定义指向类A的对象数组的指针。AA *p5;A (*p) 5;(A *) p5; A *p ;(9)说明语句const char *ptr;中,ptr是( A )。 A指向字符常量的指针; 指向字符的常量指针;指向字符串常量的指针; 指向字符串的常量指针。(10)关于new运算符的下列描述中,( B )是错的. 使用它创建对象时要调用构

2、造函数; 使用它创建对象数组时必须指定初始值; 它可以用来动态创建对象和对象数组; 使用它创建的对象或对象数组可以使用运算符delete删除。(1) 派生类的对象对它的基类成员中(C )是可以访问的公有继承的保护成员; 公有继承的私有成员;公有继承的公有成员;私有继承的公有成员(2) 下面关于派生类的描述中,(D )是错的。一个派生类可以作为另一个派生类的基类;派生类至少有一个基类;派生类的成员除了它自己的成员外,还包含了它的基类的成员 派生类中继承的基类成员的访问权限到派生类保持不变。(3)派生类的构造函数的成员初始化列表中,不能包含(C )基类的构造函数调用; 派生类对象成员的初始化;基类

3、对象成员的初始化; 派生类中一般数据成员的初始化(4)设置虚基类的目的是(B ) 减少目标代码;消除二义性;提高运行效率; 简化程序。(5) 带有虚基类的多层派生类构造函数的成员初始化列表中都要列出虚基类的构造函数,这样将对虚基类的子对象初始化(A )一次; 二次; 多次; 与虚基类下面的派生类个数有关(1) 以下保留字( A)不能出现在说明虚函数原型的语句中。Astatic B. operator C. void D. const .(2) 以下关于虚函数和纯虚函数的说法中,( D)是不正确的A在派生类中虚函数可以不用关键字virtual说明。B. 虚函数在派生类中可以不重定义。C. 不能为

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

5、以下关于多态性的说法中,( D)是不正确的A每个多态类的对象有一个虚表指针。B. 虚函数调用与this指针无关。C. 每个多态类的基类都有一个虚函数表。D. 多态类的每一个派生类都有一个虚函数表。(1)下列不是C+流对象的是( D ) A.cout B.cin C.cerr D.ostream(2)已知:int w=-3,x=10,z=7 执行下面的语句的输出结果为( A )cout(10?x+100:x-10) (w+|z+)(!wz)(w& A. 0111 B.1111 C.0101 D.0100(3)void main()coutsetfill(*)setw(10)10endl;的输出结

6、果为( C ) A. $ 10 10 B.*10 C. *10 D.*1010(4)C+所有输入和输出流的基类是( D ) A.stream.h B.iostream.h C.cin和cout D.ios(5)文件的输入与输出流是( B ) A. iostream.h B. ifstream和ofstream C. istream_withassign,ostream_withassign D. istream和ostream(6)语句coutoct12;的输出结果是 C A.12 B.1100 C.14 D. C (7)对进行重载的语句 istream & operatora D. x.a1

7、09. 假定AA为一个类,a()为该类公有的函数成员,x为该类的一个对象,则访问x对象中函数成员a()的格式为( )。 A. x.a 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.a111. 假定AA为一个类,a为该类私有的数据成员,GetValue()为该类公有函数成员,它返回a的值,x为该类的一个对象,则访问x对象中数据成员a的格式为( )。GetValue() D. x.GetValue() 112

8、. 假定AA为一个类,int a()为该类的一个成员函数,若该成员函数在类定义体外定义,则函数头为( )。 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: 114. 若需要把一个类外定义的成员函数指明为内联函数,则必须把关键字( )放在函数原型或函数头的前面。 A. in B. inline C. inLine D. InLiner 115. 在多文件结构的程序中,通常把类的定义

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

10、的cout标识符是系统类库中定义的( )类中的一个对象。 121. 假定AA是一个类,abc是该类的一个成员函数,则参数表中隐含的第一个参数的类型为( )。 A. int B. char C. AA D. AA* 122. 假定AA是一个类,abc是该类的一个成员函数,则参数表中隐含的第一个参数为( )。 A. abc B. *this C. this D. this& 123. 假定AA是一个类,“AA& abc();”是该类中一个成员函数的原型,若该函数存在对*this赋值的语句,当用x.abc()调用该成员函数后,x的值( )。 A. 已经被改变 B. 可能被改变 C. 不变 D.不受函

11、数调用的影响 124. 假定AA是一个类,“AA* abc()const;”是该类中一个成员函数的原型,若该函数返回this值,当用x.abc()调用该成员函数后,x的值( )。 C. 不变 D. 受到函数调用的影响 125. 类中定义的成员默认为( )访问属性。 A. public B. private C. protected D. friend 126. 结构中定义的成员默认为( )访问属性。 127. 当类中一个字符指针成员指向具有n个字节的存储空间时,它所能存储字符串的最大长度为( )。 A. n B. n+1 C. n-1 D. n-2 128. 在一个用数组实现的队列类中,假定数

12、组长度为MS,队首元素位置为first,队列长度为length,则队尾(即最后一个)元素的位置为( )。 A. length+1 B. first+length C. (first+length-1)%MS D. (first+length)%MS 129. 在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队尾的后一个位置为( )。 130. 在一个用数组实现的队列类中,假定数组长度为MS,队首元素位置为first,队列长度为length,则队首的后一个位置为( )。 A. first+1 B. (first+1)%MS C. (first-

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

14、il表示,若链队为空,则进行插入时必须把新结点的地址赋给( )。 C. elemHead和elemTail D. elemHead或elemTail 133. 队列具有( )的操作特性。 A. 先进先出 B. 先进后出 C. 进出无序 D. 进出任意 134. 栈具有( )的操作特性。 135. 对于一个类的构造函数,其函数名与类名( )。 A. 完全相同 B. 基本相同 C. 不相同 D. 无关系 136. 对于一个类的析构函数,其函数名与类名( )。 A. 完全相同 B. 完全不同 C. 只相差一个字符 D. 无关系 137. 类的构造函数是在定义该类的一个( )时被自动调用执行的。 A.

15、 成员函数 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为一个类,则执行 “AB x(a,5); 143

16、. 假定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. 构造 C. 任一成员 D. 友元 146. 当类中的一个整型指针成员指向一块具有n*sizeof(int)大小的存储空间时,它最多能够存储( )个整数。 A. n B. n+1 C. n-1 D. 1 14

17、7. 假定一个类的构造函数为 “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); A. 1和0 B. 1和4 C. 4和1 D. 4和0 149. 假定AB为一个类,则( )为该类的拷贝构造函数的原型说明。 A. AB(AB x); B. AB(AB& x); C. void AB(AB& D. AB(int x);

18、 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,当用户不定义任何构造函数时,系统为该类定义的无参构造函数为( )。 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()

19、: a(0) C. AB(int aa=0) a=aa; D. AB(int aa) 153. 对于任一个类,用户所能定义的构造函数的个数至多为( )。 A. 0 B. 1 C. 2 D. 任意个 154. 对于任一个类,用户所能定义的析构函数的个数至多为( )。 155. 假定AB为一个类,则执行 “AB *px=new ABn;”语句时将( )。 A. 动态分配一个数组 B. 动态分配一个对象 C. 静态分配一个数组 D. 静态分配一个对象 156. 设px是指向一个类对象的指针变量,则执行 “delete px;”语句时,将自动调用该类的( )。 A. 无参构造函数 B. 带参构造函数

20、C. 析构函数 D. 拷贝构造函数 157. 当一个类对象离开它的作用域时,系统自动调用该类的( )。 A. 无参构造函数 B. 带参构造函数 C. 拷贝构造函数 D. 析构函数 158. 假定一个类对象数组为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为

21、一个类,则执行 “AB a, b(3), *p;”语句时共调用该类构造函数的次数为( )。 A. 2 B. 3 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个对象的动态数组的指针

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

23、1. 一个类的静态数据成员所表示属性 ( )。 A. 是类的或对象的属性 B. 只是对象的属性 C. 只是类的属性 D. 类和友元的属性 172. 类的静态成员的访问控制( )。 A. 只允许被定义为private B. 只允许被定义为private或protected C. 只允许被定义为public D. 可允许被定义为private、protected或public 173. 静态成员函数对类的数据成员访问( )。 A. 是不允许的 B. 只允许是静态数据成员 C. 只允许是非静态数据成员 D. 可允许是静态数据成员或非静态数据成员 174. 被非静态成员函数访问的类的数据成员( )。 A. 可以是非静态数据成员或静态数据成员 B. 不可能是类的静态数据成员 C. 只能是类的非静态数据成员 D. 只能是类的静态数据成员 175. 静态数据成员的初始化是在( )中进行的。 A

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2