选择题
    1. 程序中主函数的名字为(    )。
        A. main      B. MAIN      C. Main      D. 任意标识符
    2. 为了提高程序的运行速度,可将不太复杂的功能用函数实现,此函数应选择(    )。
        A. 内联函数    B.重载函数    C.递归函数    D.函数模板
    3. 将两个字符串连接起来组成一个字符串时,选用(    )函数。
        A. strlen()    B. strcap()    C. strcat()    D. strcmp()
4. 对于任一个类,用户所能定义的析构函数的个数至多为(    )。
        A. 0      B. 1      C. 2      D. 任意个
    5. 对类中引用成员的初始化是通过构造函数中给出的(    )实现的。
        A. 函数体      B. 参数表        C. 初始化表      D. 初始化表或函数体
6. 假定AB为一个类,则执行“AB x(a,5);”语句时将自动调用该类的(    )。
        A. 带参构造函数          B. 无参构造函数 
        C. 拷贝构造函数          D. 赋值重载函数
7. 对于任一个类,用户所能定义的析构函数的个数至多为(    )。
        A. 0      B. 1      C. 2      D. 任意个
8. 用new运算符创建一维整型数组的正确语句是__________。
        A. int *p=new a[10];      B.int *p=new float[10];
        C. int *p=new int[10];    D.int *p=new int[5]={1,2,3,4,5}
    9. 假定有定义“int b[10]; int *pb;”,则不正确的赋值语句为(    )。
        A. pb=b;      B. pb=&b[0];      C. pb=new int;      D. pb=b[5];
    10. 程序中主函数的名字为(    )。
        A. main      B. MAIN      C. Main      D. 任意标识符
    11. 为了提高程序的运行速度,可将不太复杂的功能用函数实现,此函数应选择(    )。
        A. 内联函数    B.重载函数    C.递归函数    D.函数模板
    12. 将两个字符串连接起来组成一个字符串时,选用(    )函数。
        A. strlen()    B. strcap()    C. strcat()    D. strcmp()
    13. 用new运算符创建一维整型数组的正确语句是__________。
        A. int *p=new a[10];      B.int *p=new float[10];
        C. int *p=new int[10];    D.int *p=new int[5]={1,2,3,4,5}
    14. 假定有定义“int b[10]; int *pb;”,则不正确的赋值语句为(    )。
        A. pb=b;      B. pb=&b[0];      C. pb=new int;      D. pb=b[5];
    15. 假定AA为一个类,a为该类公有的数据成员,x为该类的一个对象,则访问x对象中数据成员a的格式为(    )。
        A. x(a)      B. x[a]      C. x->a      D. x.a
    16. 假定AB为一个类,则执行“AB x(a,5);”语句时将自动调用该类的(    )。
        A. 带参构造函数          B. 无参构造函数 
        C. 拷贝构造函数          D. 赋值重载函数
    17. 对于任一个类,用户所能定义的析构函数的个数至多为(    )。
        A. 0      B. 1      C. 2      D. 任意个
    18. 对类中引用成员的初始化是通过构造函数中给出的(    )实现的。
        A. 函数体      B. 参数表        C. 初始化表      D. 初始化表或函数体
    19. 如果表达式a==b中的“==”是作为普通函数重载的运算符,若采用运算符函数调用格
式,则可表示为(    )。
        A. a.operator==(b)    B. b.operator==(a)
        C. operator==(a,b)    D. operator==(b,a)
填空题
1.若只需要通过一个成员函数读取其数据成员的值,而不需要修改它们,则应在函数头的后面加上________关键字;若只需要读取引用参数的值,不需要对其修改,则应在该参数说明的开始使用__________关键字。
2.假定一个类对象数组为A[N],当定义该数组时,将自动调用该类的无参构造函数的次数为________次,当离开它的作用域时,将自动调用该类析构函数的次数为________次。
3.假定AB为一个类,则类定义体中的“AB(AB& x);”语句为该类______________的原型语句,而“operator=(AB& x);”为该类______________的原型语句。
4. 在定义一个派生类时,使用__________关键字表示为私有继承,使用__________关键编程递归函数
字表示为公有继承。
5. 元素类型为double的二维数组a[4][6]共有________个元素,共占用________字节的存储空间。
6. 假定对二维数组a[3][4]进行初始化的数据为{{3,5,6},{2,8},{7}},则a[1][1]和a[2][3]分别被初始化为_______和________。
7. 假定p为指向二维数组int d[4][6]的指针,则p的类型为________,其中一个元素d[i][j]表示成指针访问方式为____________。
8.假定一个类对象数组为A[N],当定义该数组时,将自动调用该类的无参构造函数的次数为________次,当离开它的作用域时,将自动调用该类析构函数的次数为________次。
9. 已知一维数组类ARRAY的定义如下,ARRAY与普通一维数组区别是:其重载的运算符[ ]要对下标是否越界进行检查。
    class ARRAY{
        int *v;      //指向存放数组数据的空间
        int s;        //数组大小 
      public: 
        ARRAY(int a[], int n);
        ~ARRAY(){delete []v;}
        int size(){ return s;}
        int& operator[](int n);
    };
    ___(1)___ operator[](int n)  //[ ]的运算符成员函数定义
    {
        if(n<0 || ___(2)___) {cerr<<"下标越界!"; exit(1);}
        return ___(3)___;
    }
    (1)                    (2)                  (3)
10. 常数-4.205和6.7E-9分别具有__________和__________位有效数字。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。