1、 print(int); print(char,char); print(char); print(int,int);11.在下列成对的表达式中,运算结果类型相同的一对是( D )2和 和72 和72 和2 l2.内联函数的特点是( D )A.减少代码量,加快访问速度 B.减少代码量,减缓访问速度C.增加代码量,减缓访问速度 D.增加代码量,加快访问速度13.类的私有成员可在何处被访问( A )A.本类的成员函数中 B.本类及子类的成员函数中C.通过对象名在任何位置 D.不可访问14.类的构造函数在以下什么情况下会被自动调用( B )A.定义成员函数时 B.定义对象时C.定义数据成员时 D.定
2、义友元函数时15.下列关于析构函数描述正确的是( D )A.可以重载 B.函数体中必须有delete语句C.返回类型必须是void类型 D.不能指定返回类型 16.设有函数T Sum(T x,T y)return x+y;,其中T为模板类型,则下列语句中对该函数错误的使用是( D )(1,2);,;(A,C);(A,C);17.下列哪个编译指令属于条件编译指令( C )A.#include B.#define C.#else D.#pragma18.关于类的静态成员函数描述错误的是( A ) A.在创建对象前不存在 B.不能说明为虚函数C.不能直接访问非静态函数 D.不是对象的成员l9.如果类
3、A被声明成类B的友元,则( D ) A.类A的成员即类B的成员 B.类B的成员即类A的成员C.类A的成员函数不得访问类B的成员 D.类B不一定是类A的友元20.派生类的对象可以访问以下那种情况继承的基类成员( D ) A.私有继承的私有成员 B.公有继承的私有成员C.私有继承的保护成员 D.公有继承的公有成员二、填空题(本大题共20小题,每小题1分,共20分)请在每小题的空格中填上正确答案。错填、不填均无分。21.若使用标准输出流把整型变量a的值输出到屏幕上,实现此操作的C+语句是 couta 。+将数据从一个对象流向另一个对象的流动抽象为“流”,从流中获取数据的操作称为 提取操作 。23.执
4、行下列代码 int b=100; coutHex:hexb; 程序的输出结果是Hex:64。24.静态联编所支持的多态性称为编译时或编译的多态性。+程序必须有且只有一个主函数,其函数名为main。26.写出声明一个复数对象的语句,并使该对象被初始化为+,此声明语句是complex num,或complex num,。27.若有函数定义为: int add(int ml=0,int m2=2,int m3=4) return ml+m2+m3; 在主函数中有int s=add(1)+add(0,1)+add(0,1,2);则执行此语句后s的值为15 28。+中使用inline关键字说明函数为内联
5、函数。29.在源程序中有宏定义:#define PI ,则若不想使该宏定义影响到程序的其它地方,可以使用#undef PI删除该宏定义。30.类和其它数据类型不同的是,组成这种类型的不仅可以有数据,还可以有对数据进行操作的函数或成员函数。31.有下列代码int a=0;double b=0;cina当用键盘输入时,b=。32.对于类Point而言,其析构函数的定义原型为Point:Point( )或Point( )。33.对象成员构造函数的调用顺序取决于这些对象在类中说明的顺序,与它们在成员初始化列表中给出的顺序无关。34.类的简单成员函数是指声明中不含const、volatile、stati
6、c关键字的函数。35.与操作对象的数据类型相互独立的算法称为泛型算法。36.从一个或多个以前定义的类产生新类的过程称为派生。37.在vector类中向向量尾部插入一个对象的方法是push_back(const T&)。+中用于动态创建对象,并返回该对象的指针的关键字是new。+的流类库预定义的与标准输出设备相联接的流是cout。40.执行下列代码coutnoshowpoint;程序输出结果是123 。三、改错题(本大题共5小题,每小题2分,共10分)下面的类定义中有一处错误,请用下横线标出错误所在行并给出修改意见。41.#include class f private:float x,y; p
7、ublic:f(float a,float b)x=a;y=b; float max()return(xy)?x:y; 求最大值 ; main( ) f a,;( )endl; return(x或return(xy:x;42.#include class testint x;test(int a)x=a; void set(int a)x=a; void get()coutx main() const test a(3);(5);();(5); a是常对象,不能被更新或const test a(3);去掉const使a不再为常对象43.#include class pointf1(float
8、a,float b)x=a; point()x=0;y=0; void getx()cout void gety()couty ; void print(point a)cout point a; print(a);print(point a)coutendl; print( )不是成员函数不允许直接调用或将private:float x,y;改为 public:或cour改为 ( );44.#includeint x,y;fl(int a,int b)x=a; void print()cout f a;,; f1( )调用时实参与形参类型不一致45.#include int x=6; con
9、st int*p=x;*pconst int *p=x; 变量给指针p赋值必须加上&四、完成程序题(本大题共5小题,每小题4分,共20分)46.完成下面程序,使其输出l0,并在退出运行时正确释放分配给指针的存储空间。#include using namespace std;void main()int *a,*p;a=new int(10);p= _a_;delete p;或delete a;47.#include using namespace std; class base base(int a)x=a; int get()return x; void showbase() coutx=
10、class Derived:public base private:int y;Derived(int a,int b):base(a)y=b; void showderived() coutget()showbase();输出结果如下:x=3x=6,y=7x=648.下面程序的运行结果如下: B:display() C: 在下划线处填上缺少的部分。源程序如下: #include class B virtual void display( ) cout B:display( ) class C:public Bvoid display()coutdisplay(); B b,*pb; C c;
11、 pb=b; fun(pb); pb=c;49.下面程序的运行结果如下: This is line1 This is line2 This is line3fstream或”fstream” fstream fin, fout; (,ios:out); if(!() return; for(int i=0;i3;i=i+1) foutThis is linei+1in); () char str100; while(!( ) (str,100); coutstr50.在下划线处填上缺少的部分。 #include template或template T fun(T x) T y; y=x*x-T
12、(5); return y; float a=2;fun(a);五、程序分析题(本大题共4小题,每小题5分,共20分)51.请写出文本文件中的内容#includefstreamvoid main() ofstream myFile1;Enter the data in Chinese format. ,2008,May 25):string Date(2008,January 1string Year=(0,4);int k=(int i=(string Month=(k+l,i-k-1);string Day=(i+1,2);string NewDate=Day+Month+Year;myF
13、ileloriginal date:DatemyFile1Converted date:NewDateoriginal date:2008,January 1 Converted date:1 January 200852.给出下面程序的输出结果class Simplepublic:Simple()x=y=0;Simple(int i,int j)x=i;y=j;void copy(Simples);void setxy(int i,int j)x=i;void print()cout=10) if(-i4=3)continue; elsei=i-i=16 i=14 i=12 i=1054.给
14、出下面程序的输出结果 int num=300; int &ref=num;ref; ref=ref-100;num; num=num-50;ref300 200 150六、程序设计题(本大题共1小题,共10分)55.定义堆栈类模板Stack(先进后出),栈的大小由使用者确定。要求该类模板对外提供 如下二种基本操作: (1)push入栈(2)pop出栈,用数组来实现 template class Stack T xsize; int current; Stack()current=0; .push(.); .pop(.); ;请写出两个函数的过程(如果需要形式参数,请给出形参类型和数量,以及返回值类型)void Satckpush(T t) if (current= =size) “The Stack is full!”exit(0); /堆栈满则程序结束else xcurrent=t;current+; /新元素入栈并修改栈顶指针T Stackpop( ) if (current= =0)”There is no object in the Stack! /堆栈空则程序结束else T a=xcurrent-1;current-;returna; /栈顶元素出栈并修改栈顶指针
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1