一、(共10分,每题1分)单项选择
1. 对于全局函数 int f(void) ,与其完全等价的函数原型为:
A. int& f( ); B. int f(void ) const; C. const int f( ); D. A、B、C都不是
2. 类A中有唯一的非静态成员函数int f(A& one)和私有的数据成员int x;,那么在此成员函数的函数体中可以有语句:
A. return one.f(this); B. x=f(this); C. this->f(x.one); D. int* const pX=&one.x;
3. 下面关于new 和delete操作符的说法,哪个是不正确的:
A. 使用new操作符,可以动态分配全局堆中的内存资源。
B. 若p的类型已由A*强制转换为void *,那么执行语句delete p;时,类A的析构函数不会被调用。
C. 实现全局函数时,new和delete通常成对地出现在由一对匹配的花括号限定的语句块中。
D. 执行语句A * p=new A[100];时,类A的构造函数只会被调用1次。
4. 类TM和类TN是两个独立的类,那么类TM中哪种形式的数据成员一定是不允许的:
A. TM* a; B. TN& a; C. TM a; D. TN a;
5. 类B是通过public继承方式从类A派生而来的,且类A和类B都有完整的实现代码,那么下列说法正确的是:
A. 类B中具有pubic可访问性的成员函数个数一定不少于类A中public成员函数的个数。
B. 一个类B的实例对象占用的内存空间一定不少于一个类A的实例对象占用的内存空间。
C. 只要类B中的构造函数都是public的,在main函数中就可以创建类B的实例对象。
D. 类A和类B中的同名虚函数的返回值类型必须完全一致。
6. 下列哪种函数可以是虚的:
A. 自定义的构造函数 B. 拷贝构造函数 C. 静态成员函数 D. 析构函数
7. 类A有一个实例化的常量对象a,那么下面的说法中不正确的是:
A. 类A中的非静态数据成员一定都是常量成员。
B. 通过a可以直接调用类A的常量成员函数。
C. a不能直接作为左值表达式使用。
D. a可以是静态常量对象。
8. 在不考虑强制类型转换的情况下,关于类中常量成员函数的下列说法不正确的是:
A. 常量成员函数中不能修改本类中的非静态数据成员。
B. 常量成员函数中可以调用本类中的任何静态成员函数。
C. 常量成员函数的返回值只能是void或常量。
D. 若常量成员函数中调用虚函数f,那么函数f在本类中也一定是一个常量成员函数。
9. 类C是以多重继承的方式从类A和类B继承而来的,类A和类B无公共的基类,那么:
A. 类C的继承方式只能采用public继承。 B. 可改用单继承的方式实现类C的同样功能。
C. 类A和类B至少有一个是抽象类。 D. 类A和类B至少有一个是虚基类。
10. 下列哪种用法不能体现类A和类B之间的组合关系:
A. 类A中声明数据成员B b;
B. 类A中声明数据成员B* b;
<
一套C++试题...
最新推荐文章于 2024-09-23 13:26:40 发布
这是一份关于C++编程的试题集,涵盖了类与对象、继承、动态内存管理、异常处理等多个方面。试题包括选择题、多选题、判断题和编程实践,旨在考察考生对C++语法、数据成员、成员函数、指针与引用、类的继承和访问控制等概念的理解和应用能力。
摘要由CSDN通过智能技术生成