贴吧大发电子技术分享dianzipa

C++中分配内存的使用_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
C++中分配内存的使用
上传于|0|0|文档简介
&&new、delete,malloc、free的区别和使用方法
阅读已结束,如果下载本文需要使用1下载券
想免费下载本文?
定制HR最喜欢的简历
你可能喜欢全国2004年10月自考面向对象程序设计试题
(完美word版)(一)
来源:91考试网
作者:www.91exam.org
全国2004年10月高等教育自学考试面向对象程序设计试题课程代码:02328一、单项选择题(本大题共10小题,每小题2分,共20分)在每小题列出的四个备选项中只有一个是符合题目要求的,请将其代码填写在题后的括号内。错选、多选或未选均无分。1.在面向对象的程序设计中,首先在问题域中识别出若干个 (   )A.函数&&&&&&&&B.类C.文件&&&&&&&&D.过程2.定义类模板时要使用关键字(   )A.const&&&&&&&&B.newC.delete&&&&&&&D.template3.在下列成对的表达式中,运算结果类型相同的一对是(   )A.9.0/2.0和9.0/2&&&&&B.9/2.0和9/2C.9.0/2和9/2&&&&&&D.9/2和9.0/2.04.已知f1和f2是同一类的两个成员函数,但f1不能直接调用f2,这说明(   )A.f1和f2都是静态函数&&&&B.f1是静态函数,f2不是静态函数C.f1不是静态函数,f2是静态函数&&D.f1和f2都不是静态函数5.调用一成员函数时,使用动态联编的情况是(   )A.通过对象调用一虚函数&&&&B.通过指针或引用调用一虚函数C.通过对象调用一静态函数&&&D.通过指针或引用调用一静态函数6.假定一个类的构造函数为“A(int aa=1, int bb=0) {a= b=}”, 则执行“Ax (4);”语句后,x.a和x.b的值分别为(   )A.1和0&&&&&&&B.1和4C.4和0&&&&&&&D.4和17.在派生类中能够直接访问的是基类的(   )A.公有成员和私有成员&&&&B.保护成员和私有成员C.不可访问的和私有的成员&&&D.公有成员和保护成员8.下列不具有访问权限属性的是(   )A.非类成员&&&&&&&B.类成员C.数据成员&&&&&&&D.函数成员9.在类定义中private, protected, public 关键词出现的次数为(   )A.任意多次&&&&&&&B.至多一次C.public至少出现一次&&&&D.至少一次10.C++语言鼓励程序员在程序设计时将(   )A.数据和操作分别封装&&&&&B.不同类型的数据封装在一起C.数据和操作封装在一起&&&&&D.不同作用的操作封装在一起二、填空题(本大题共10小题,每小题2分,共20分)请在每小题的空格中填上正确答案。错填、不填均无分。11.在用C++进行程序设计时,最好用___________________代替malloc。12.函数模板中紧随template之后尖括号内的类型参数都要冠以保留字________________。13.在ios类中定义的用于控制输入输出格式的枚举常量中,用于代表十进制、八进制和十六进制的3个枚举常量是dec、oct和___________________。14.如果重载了运算符+,则相应的运算符函数名是___________________。15.由static修饰的数据成员为该类的所有对象___________________。16.为了实现多态性,派生类需重新定义基类中的___________________。17.编译时的多态性通过___________________函数实现。18.在派生类中实现基类成员的初始化,需要由派生类的构造函数调用_________________来完成。19.在C++中,访问指针所指向的对象的成员使用运算符___________________。20.重载函数在参数类型或参数个数上不同,但___________________相同。三、改错题(本大题共5小题,每小题2分,共10分)21.下面的类Complex 定义中有一处错误,如更正了错误,程序的输出是5+8i。请用下横线标出错误所在行并给出修改意见。#include &&&&&&&&&&&&&#include &&&&&&&&&&&&&&class Complex{ &&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&public: &&&&&&&&&&&&&&&&&&& Complex (double r=0.0, double i=0.0): real (r), imag (i){} &&&&&&&& void show(){cout&<REAL<=0?′+′: ′-′) &<FABS(IMAG)<<′I′;}&&&& friend Complex& operator += (Complex c1, Complex c2){ &&&&&&&&&&& c1.real+=c2. c1.imag+=c2. &&&&&&&&&&&&&& &&&&& return c1; &&&&&&&&&&&&&&&& && }&&&&&&&&&&&&&&&&&&& };&&&&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&&&&&& void main ( ){&&&&&&&&&&&&&&&&& && Complex c (3,5); &&&&&&&&&&&&&&& && c+=Complex (2,3); &&&&&&&&&&&&&&& && c.show ( ); &&&&&&&&&&&&&&&&& }&&&&&&&&&&&&&&&&&&&& 22.下面的程序有一处错误,请用下横线标出错误所在行并给出修改意见。#include &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&class shape {&&&&&&&&&&&&&&&&public: &&&&&&&&&&&&&&&&&&& int area () {return 0;} &&&&&&&&&&&&&};&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&class rectangle: public shape {&&&&&&&&&&&&&public: &&&&&&&&&&&&&&&&&& int a, &&&&&&&&&&&&&&&&& && void setLength (int x, int y) {a=x; b=y;} &&&&&&&&&&& && int area () {return a*b; }&&&&&&&&&&&&&& }; &&&&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&&&&&& void main () {&&&&&&&&&&&&&&&&& && &&&&&&&&&&&&&&&& && r. setLength (3,5); &&&&&&&&&&&&&&& && shape*s=r; &&&&&&&&&&&&&&&&& && cout && r.area () &<ENDL; && cout && s.area () &<ENDL; }&&&&&&&&&&&&&&&&&&&& 23.下面的程序有一处错误,请用下横线标出错误所在行并提出修改意见。#include &&&&&&&&&&&&&&class CU {&&&&&&&&&&&&&&&&&&& enum {INT, FLOAT} &&&&&&&&&&&&&& union value { &nb来源:www.91exam.org&&&&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&&& };&&&&&&&&&&&&&&&&&&public: &&&&&&&&&&&&&&&&&&& CU (int x): type (INT), ivalue (x){} &&&&&&&&&&&&& CU (float y): type (FLOAT), fvalue (y) {}&&&&&&&&&&& && Void print () {&&&&&&&&&&&&&& &&& &&&&& if (type ==INT) &&&&&&&&&&&&&&& &&&&&&&& cout && &&&&&&&&&&&&&& &&&&& else &&&&&&&&&&&&&&&&& &&&&&&&& cout && &&&&&&&&&&&&&& && }&&&&&&&&&&&&&&& &&&&& }; &&&&&&&&&&&&&&&&&&& &&&&&&&&&&&&&&&&&&&& void main (){&&&&&&&&&&&&&&&&& && CU fCU ((float) 5.6); &&&&&&&&&&&&& CU iCU (8); &&&&&&&&&&&&&&&& && fCU.print ();&&&&&&&&&&&&&&&& && cout && &&&&&&&&&&&&&&& && iCU.print ();&&&&&&&&&&&&&&&&& }&&&&&&&&&&&&&&&&&&&& 24.下面的类定义中有一处错误,请用下横线标出错误所在行并说明错误原因。class A {&&&&&&&&&&&&&&&&&&& int a,b; &&&&&&&&&&&&&&&&public: &&&&&&&&&&&&&&&&&&& A(int aa=0, int bb){ &&&&&&&&&&&&&&&&&&& a= b= &&&&&&&&&&&&&&&&& }&&&&&&&&&&&&&&&&&&}; &&&&&&&&&&&&&&&&&&25.下面的类定义中有一处错误,请用下横线标出错误所在行并说明错误原因。class Location {&&&&&&&&&&&&&&&&&&&&&&& int X, Y; &&&&&&&&&&&&&&&& protected: &&&&&&&&&&&&&&&&&&&&&&& int SetZero (int zeroX, int xeroY); &&&&&&&&&&& private: &&&&&&&&&&&&&&&&&&&&&&& int length, &&&&&&&&&&&&&& public: &&&&&&&&&&&&&&&&&&&&&&&& void Location (int initX, int initY); &&&&&&&&&&&&&&&&& int GetX ();&&&&&&&&&&&&&&&&&&&&& int GetY ();&&&&&&&&&&&&&&& };&&&&&&&&&&&&&&&&&&&
网站客服QQ:后使用快捷导航没有帐号?
查看: 1882|回复: 0
malloc和free(及其变体)会产生问题的原因在于它们太简单:他们不知道构造函数和析构函数。
假设用两种方法给一个包含10个string对象的数组分配空间,一个用malloc,另一个用new:string *stringArray1 =
&& static_cast&string*&(malloc(10 * sizeof(string)));
string *stringArray2 = new string[10];复制代码其结果是,stringArray1确实指向的是可以容纳10个string对象的足够空间,但内存里并没有创建这些对象。而且,如果你不从这种晦涩的语法怪圈(详见条款M4和M8的描述)里跳出来的话,你没有办法来初始化数组里的对象。换句话说,stringArray1其实一点用也没有。相反,stringArray2指向的是一个包含10个完全构造好的string对象的数组,每个对象可以在任何读取string的操作里安全使用。
假设你想了个怪招对stringArray1数组里的对象进行了初始化,那么在你后面的程序里你一定会这么做:& & free(stringArray1);
& & delete [] stringArray2;& && &// 参见条款5:这里为什么要加上个&[]&复制代码调用free将会释放stringArray1指向的内存,但内存里的string对象不会调用析构函数。如果string对象象一般情况那样,自己已经分配了内存,那这些内存将会全部丢失。相反,当对stringArray2调用delete时,数组里的每个对象都会在内存释放前调用析构函数。
既然new和delete可以这么有效地与构造函数和析构函数交互,选用它们是显然的。
把new和delete与malloc和free混在一起用也是个坏想法。对一个用new获取来的指针调用free,或者对一个用malloc获取来的指针调用delete,其后果是不可预测的。大家都知道“不可预测”的意思:它可能在开发阶段工作良好,在测试阶段工作良好,但也可能会最后在你最重要的客户的脸上爆炸。
new/delete和malloc/free的不兼容性常常会导致一些严重的复杂性问题。举个例子,&string.h&里通常有个strdup函数,它得到一个char*字符串然后返回其拷贝:& & char * strdup(const char *ps);& && &// 返回ps所指的拷贝复制代码在有些地方,C和C++用的是同一个strdup版本,所以函数内部是用malloc分配内存。这样的话,一些不知情的C++程序员会在调用strdup后忽视了必须对strdup返回的指针进行free操作。为了防止这一情况,有些地方会专门为C++重写strdup,并在函数内部调用了new,这就要求其调用者记得最后用delete。你可以想象,这会导致多么严重的移植性问题,因为代码中strdup以不同的形式在不同的地方之间颠来倒去。
C++程序员和C程序员一样对代码重用十分感兴趣。大家都知道,有大量基于malloc和free写成的代码构成的C库都非常值得重用。在利用这些库时,最好是你不用负责去free掉由库自己malloc的内存,并且/或者,你不用去malloc库自己会free掉的内存,这样就太好了。其实,在C++程序里使用malloc和free没有错,只要保证用malloc得到的指针用free,或者用new得到的指针最后用delete来操作就可以了。千万别马虎地把new和free或malloc和delete混起来用,那只会自找麻烦。既然malloc和free对构造函数和析构函数一无所知,把malloc/free和new/delete混起来用又象嘈杂拥挤的晚会那样难以控制,那么,你最好就什么时候都一心一意地使用new和delete吧。
Powered by Discuz!
& Comsenz Inc.的代码;D.保证基类公有成员在子类中可以被访问答案:C;解析:(P86)C++要求函数在被调用之前,应当;原型提供的信息去检查调用的合法性,强制参数转换成;标准库函数,其声明在头文件中,可以用#inclu;数,先定义、后调用的函数可以不用声明,但后定义、;的可理解性,常将主函数放在程序开头,这样需要在主;,以消除函数所在位置的影响;B.使用它创建的对象或对象
D. 保证基类公有成员在子类中可以被访问 答案:C
解析:(P86)C++要求函数在被调用之前,应当让编译器知道该函数的原型,以便编译器利用函数
原型提供的信息去检查调用的合法性,强制参数转换成为适当类型,保证参数的正确传递。对于
标准库函数,其声明在头文件中,可以用#include宏命令包含这些原型文件;对于用户自定义函
数,先定义、后调用的函数可以不用声明,但后定义、先调用的函数必须声明。一般为增加程序
的可理解性,常将主函数放在程序开头,这样需要在主函数前对其所调用的函数一一进行声明
,以消除函数所在位置的影响。所以选择C项。 16. 关于new运算符的下列描述中,错误的是() A. 它可以用来动态创建对象和对象数组
B. 使用它创建的对象或对象数组可以使用运算符delete删除 C. 使用它创建对象时要调用构造函数
D. 使用它创建对象数组时必须指定初始值 答案:D
解析:(P78)new创建的对象数组不能指定初始值,所以调用无参的构造函数,选择D项。 17. 已知:p是一个指向类A数据成员m的指针,A1是类A的一个对象。如果要给m赋值为5,正确 的是() A. A1.p=5; B. A1-&p=5; C. A1.*p=5; D. *A1.p=5; 答案:C
解析:(P118)A中p是指针即地址,错误;B选项中A1不是指针不能使用指向运算符-&,错误
;“*”比“.”级别要高,所以D选项*A1.p=5相当于(*A1).p=5;错误。另外涉及到指向成员函数 时注意以下几点:
指向成员函数的指针必须于其赋值的函数类型匹配的三个方面:(1)参数类型和个数;(2)返回 类型;(3)它所属的类类型。
成员函数指针的声明:指向short型的Screen类的成员的指针定义如下:
short Screen::* ps_S
ps_Screen可以用_height的地址初始化如下:short Screen::*ps_Screen=&Screen::_
类成员的指针必须总是通过特定的对象或指向改类型的对象的指针来访问。是通过使用两个指
向成员操作符的指针(针对类对象和引用的.*,以及针对指向类对象的指针的-&*)。
18. 以下基类中的成员函数表示纯虚函数的是() A. virtual void tt()=0 B. void tt(int)=0
C. virtual void tt(int) D. virtual void tt(int){} 答案:A
解析:(P173)当在基类中不能为虚函数给出一个有意义的实现时,可以将其声明为纯虚函数,实 现由派生类完成。格式:virtual&函数返回类型说明符&&函数名&(&参数表&)=0;。
19. C++类体系中,不能被派生类继承的有() A. 常成员函数 B. 构造函数 C. 虚函数
D. 静态成员函数 答案:B
解析:(P132)构造函数不能被继承。 20. 静态成员函数不能说明为()
A. 整型函数 B. 浮点函数 C. 虚函数 D. 字符型函数
解析:(P108)使用关键字static声明的成员函数就是静态成员函数,静态成员函数也属于整个类
而不属于类中的某个对象,它是该类的所有对象共享的成员函数。 静态成员函数可以在类体内定义,也可以在类外定义。当在类外定义时,要注意不能使用 static关键字作为前缀。
由于静态成员函数在类中只有一个拷贝(副本),因此它访问对象的成员时要受到一些限制:静
态成员函数可以直接访问类中说明的静态成员,但不能直接访问类中说明的非静态成员;若要访
问非静态成员时,必须通过参数传递的方式得到相应的对象,再通过对象来访问。虚函数是非静
态的、非内联的成员函数。静态成员函数不能被说明为虚函数。 二、填空题(本大题共20小题,每小题1分,共20分)请在每小题的空格中填上正确答案 。错填、不填均无分。
1. 假设int a=1,b=2;则表达式(++a/b)*b--的值为___。 答案:2
[解析]前缀++或DD表示先使变量值变化,再使用,这和后缀恰恰相反。但是编译
cout&&(++a/b)*b--时,先++a/b值为1,后1*b--,先取b=2,结果为2,再让b=1。
2. 抽象类中至少要有一个___函数。 答案:(P173)纯虚
[解析]至少有一个纯虚函数的类就称为抽象类,即不能实例化。 3. 一个抽象类的派生类可以实例化的必要条件是实现了所有的___。
答案:(P173)纯虚函数的定义
[解析]抽象类只因有纯虚函数,所以不能被实例化,所以派生类要实例化必须对纯虚函数进行 定义。
4. 下面程序的输出结果为___。 #include &iostream.h& void main() {int num=2,i=6; do {i--; num++;
}while(--i); cout&&num&& }
[解析]do-while循环,前缀先使i减少1后判断是否为零,不为零时再次执行循环,为零退出
循环。循环值执行3次就退出,所以结果为5。
5. 静态成员函数、友元函数、构造函数和析构函数中,不属于成员函数的是___。
答案:(P109)友元函数
[解析]友元函数不是类成员,但可以访问类成员。类的封装性保证了数据的安全,但引入友元
,虽然访问类是方便了,但确实破坏类访问的安全性。 6. 在用C++进行程序设计时,最好用___代替malloc。 答案:(P10)new
[解析]new与delete是C++语言特有的运算符,用于动态分配和释放内存。new用于为各种数据
类型分配内存,并把分配到的内存首地址赋给相应的指针。new的功能类似于malloc()函数。 使用new的格式为:
&指针变量&new&数据类型&;
其中,&数据类型&可以是基本数据类型,也可以是由基本类型派生
出来的类型;&指针变量&取得
分配到的内存首地址。new有3种使用形式。 (1)给单个对象申请分配内存
int *ip=//ip指向1个未初始化的int型对象 (2)给单个对象申请分配内存的同时初始化该对象
int *ip=new int(68);//ip指向1个表示为68的int型对象 (3)同时给多个对象申请分配内存
int *ip=new int[5];//ip指向5个未初始化的int型对象的首地址
for(int i=0;i&5;i++)ip[i]=5*i+1;//给ip指向的5个对象赋值 [解析]传地址即指针,在函数中通过指针修改它指向的变量的值时,实参也就变化了。使用引
用,直接修改变量的别名即引用的值,该变量也就随着变化。 18. 语句序列
infile.open(“data.dat”);
的功能可用一个语句实现,这个语句是___。 答案:(P199)ifstream infile(“data.dat”);
[解析]void ifstream::open(const char *fname,int mode=ios::in,int
用new申请分配内存时,不一定能申请成功。若申请失败,则返回NULL,即空指针。因此,在程
序中可以通过判断new的返回值是否为0来获知系统中是否有足够的空间供用户使用。
7. 由const修饰的对象称为___。 答案:(P113)常对象
[解析]使用const关键字说明的成员函数称为常成员函数,使用const关键字说明的对象称为常 对象。
常成员函数的说明格式如下:&返回类型说明符&&成员函数名&(&参数表&)
常成员函数不更新对象的数据成员,也不能调用该类中没有用const修饰的成员函数。常对象
只能调用它的常成员函数,而不能调用其他成员函数。const关键字可以用于参与重载函数的区 分。
8. 在C++程序设计中,建立继承关系倒挂的树应使用___继承。 答案:(P138)单
[解析]一个基类可以派生多个子类,一个子类可以再派生出多个子类,这样就形成了一个倒立 的树。
9. 基类的公有成员在派生类中的访问权限由___决定。 答案:(P132)访问控制方式或继承方式 10. 不同对象可以调用相同名称的函数,但执行完全不同行为的现象称为___。
答案:(P167)多态性
[解析]多态性的概念。虚函数是实现多态的基础,运行过程中的多态需要同时满足3个条件
:(1)类之间应满足子类型关系。(2)必须要有声明的虚函数。(3)调用虚函数操作的是指向对象
的指针或者对象引用;或者是由成员函数调用虚函数(如果是在构造函数或析构函数中调用虚函 数,则采用静态联编)。
11. this指针始终指向调用成员函数的___。 答案:对象
this指针是隐藏的指针,它指向调用函数的对象。 12. 预处理命令以___符号开头。 答案:(P183)operater
[解析]文件包含、预处理和编译都是以#开头。 13. 类模板用来表达具有___的模板类对象集。 答案:(P145)相同处理方法
[解析]模板特点是不同的数据具有相同的处理方法的抽象。 14. C++程序的源文件扩展名为___。 答案:(P21)cpp
[解析]源程序*.cpp,目标文件为*.obj,可执行程序*.exe。 15. 在#include命令中所包含的头文件,可以是系统定义的头文件,也可以是___的头文件。 答案:(P7)自定义
[解析]#include装入文件有两种方式&&和“”,一是系统的,一是自定义文件。
16. vector类中向向量尾部插入一个对象的方法是___。 答案:(P157)push_back
17. C++语言中如果调用函数时,需要改变实参或者返回多个值,应该采取___方式。
答案:(P51)传地址或引用
access=filebuf::openprot);
ifstream::ifstream(const char *fname,int mode=ios::in,int access=filebuf::openprot);
其中,第一个参数是用来传递文件名的;第二个参数mode的值决定文件将如何被打开;第三个参
数access的值决定文件的访问方式,一般取缺省值filebuf::openprot,表示是普通文件。
mode的取值如下:(1)ios::in:打开一个文件进行读操作,而且该文件必须已经存在 ;(2)ios::nocreate:不建立新的文件。当文件不存在时,导致open()失败
;(3)ios::noreplace:不修改原来已经存在的文件。若文件已经存在,导致open()失败
;(4)ios::binary:文件以二进制方式打开,缺省时为文本文件。 19. 如果要把类B的成员函数void fun()说明为类A的友元函数,则应在类A中加入语句___。
答案:(P111)friend void B::fun();
[解析]声明成员函数作为另外一个类的友元函数时,使用类作用域运算符::。
20. 在编译指令中,宏定义使用___指令。 答案:(P6、97)#define
[解析]静态成员是所有对象共享的特征,也就是类的特征。
五、程序分析题(本大题共4小题,每小题5分,共20分) 1. 给出下面程序输出结果。 #include &iostream.h& class example { public:
example(int b=5){a=b++;}
void print(){a=a+1;cout &&a&&&&;} void print()const {cout&&a&&} };
void main() {
const example y(2); x.print(); y.print(); }
[解析]x是普通对象,调用普通的print函数;而y常对象,调用常成员函数。
2. 给出下面程序输出结果。 #include &iostream.h& void main() { int *p1; int **p2=&p1; int b=20; p1=&b;
cout&&**p2&& }
[解析]p1指向b,而p指向p1的地址。*p2表示p1的地址,p1的地址就是&b,即*p2是&b,所以
**p2就是b变量的值。
3. 给出下面程序输出结果。 #include &iostream.h& class Base {private: int Y; public:
Base(int y=0) {Y=y;cout&&&Base(&&&y&&&)\n&;} ~Base() {cout&&&~Base()\n&;} void print() {cout &&Y&& &&;} };
class Derived:public Base {private: int Z; public:
Derived (int y, int z):Base(y) {Z=z;
cout&&&Derived(&&&y&&&,&&&z&&&)\n&; }
~Derived() {cout&&&~Derived()\n&;} void print() {Base::print(); cout&&Z&& } };
void main()
{Derived d(10,20); d.print(); }
答案:Base(10) Derived(10,20) 10 20
~Derived() ~Base()
[解析]派生类对象,先调用基类构造函数输出Base(10),后调用派生类构造函数输出
Derived(10,20),后执行d.print(),调用派生类的print,再调用Base::print()输出10,后返回
输出z的值20。后派生类析构,再基类析构。 4. 给出下面程序输出结果。 #include &iostream.h& class A {public: A()
{cout&&&A 构造函数\n&;fun();} virtual void fun()
{cout&&&A::fun() 函数\n&;} };
class B:public A {public: B()
{cout&&&B构造函数\n&;fun();}
void fun() {cout&&&B::fun() calle函数\n&;} };
void main() {B}
答案:A构造函数 A::fun()函数 B构造函数
B::fun()calle函数
[解析]定义派生类对象,首先调用基类构造函数,调用A类中fun(),然后调用B类的构造函数 ,在调用B的fun函数。
六、程序设计题(本大题共1小题,共10分)
1. 编写类String的构造函数、析构函数和赋值函数和测试程序。
已知类String的原型为: #include &iostream.h& #include &string.h& class String {public:
String(const char *str=NULL); // 普通构造函数 String(const String &other); // 拷贝构造函数 ~String(); // 析构函数
String & operator=(const String &other); // 赋值函数 void show()
{cout&&m_data&& }
char *m_ // 用于保存字符串 };
答案:String::~String()
{delete[]m_//由于m_data是内部数据类型,也可以写成delete m_ }
String::String(const char *str) {if(str==NULL)
{m_data=new char[1];//若能加NULL判断则更好 *m_data=\0; } else
{int length=strlen(str);
m_data=new char[length+1]; //若能加NULL判断则更好 strcpy(m_data, str); } }
String::String(const String &other) {int length=strlen(other.m_data);
m_data=new char[length+1];//若能加NULL判断则更好 strcpy(m_data, other.m_data); }
String & String::operator=(const String &other) {if(this==&other) return * delete[]m_
int length=strlen(other.m_data);
m_data=new char[length+1];//若能加NULL判断则更好 strcpy(m_data, other.m_data); return * }
void main()
{String str1(&aa&),str2; str1.show(); str2=str1; str2.show();
String str3(str2); str3.show(); }__
C++程序设计模拟试卷(三)
一、单项选择题
1. 设有定义double j=5;,则10+i+j值的数据类型是()A. int B. double C. float D. 不确定 答案:B
解析:考察数据的转换,j是double类型,运算只能作同类型的运算,所以要转换,而int能自动
转换为double类型,所以结果是double类型。
2. 要禁止修改指针p本身,又要禁止修改p所指向的数据,这样的
指针应定义为()
A. const char *p=“ABCD”; B. char *const p=“ABCD”; C. char const *p=“ABCD”;
D. const char * const p=“ABCD”; 答案:D
解析:(P12)const char *p说明禁止通过p修改所指向的数据。char 8. 友元关系不能() A. 提高程序的运行效率 B. 是类与类的关系
C. 是一个类的成员函数与另一个类的关系 D. 继承
解析:(P111)友元可以是函数与类的关系即友元函数,也可以类与* const p则说明不能修改
指针p的地址。因此const char * const p=“ABCD”;它禁止修改指针p本身,又禁止修改p所指 向的数据。
3. 类的构造函数被自动调用执行的情况是在定义该类的() A. 成员函数时 B. 数据成员时 C. 对象时 D. 友元函数时 答案:C
解析:(P75)建立对象时,自动构造函数的初始化对象,是系统自动调用的。而成员函数、友元
函数,需要用户直接调用,因此选择C项。
4. 已知类A是类B的友元,类B是类C的友元,则() A. 类A一定是类C的友元 B. 类C一定是类A的友元
C. 类C的成员函数可以访问类B的对象的任何成员 D. 类A的成员函数可以访问类B的对象的任何成员 答案:C
解析:(P105)友元说明方法如下: friend?&类名&;//友元类类名 使用友元可以访问所有成员: (1)友元关系不能被继承。
(2)友元关系是单向的,不具有交换性。所以,B项和D项错误。 (3)友元关系不具有传递性。所以,A项错误。 5. 假定一个类的构造函数为“A(int i=4, int j=0) {a=i;b=j;}”, 则执行“A x (1);”语
句后,x.a和x.b的值分别为() A. 1和0 B. 1和4 C. 4和0 D. 4和1 答案:A
解析:(P75)带默认的构造函数,对应实参没有值时就采用形参值。调用构造函数时,i=1,不采
用默认值,而只有一个参数,j采用默认值0即j=0,因此a=1,b=0,选择A项。
6. 关于this指针使用说法正确的是()
A. 保证每个对象拥有自己的数据成员,但共享处理这些数据的代码
B. 保证基类私有成员在子类中可以被访问。 C. 保证基类保护成员在子类中可以被访问。 D. 保证基类公有成员在子类中可以被访问。 答案:A
解析:(P86)this指针是隐藏的,可以使用该指针来访问调用对象中的数据。基类的成员在派生
类中能否访问,与继承方式有关,与this没有关系。所以选择A项。 7. 所谓多态性是指 ()
A. 不同的对象调用不同名称的函数 B. 不同的对象调用相同名称的函数 C. 一个对象调用不同名称的函数 D. 一个对象调用不同名称的对象 答案:B
解析:(P167)多态性有两种静态多态性和动态多态性,静态多态性是指调用同名函数,由于参数 的不同调用不同的同名函数;动态多态性是指不同对象调用同名函数时,由于对象不同调用不同
的同名函数。 多态性肯定具有相同的函数名,所以选择B项。
类的关系即友元类,但友元不 能继承,是单向性,且不具有传递性。友元可以访问类中所有成员,提高了访问的方便性。因此 选择D项。
9. 语句ofstream f(“TEMP.DAT”,ios::app|ios::binary)?的功能是建立流对象f,试图打
开文件TEMP.DAT 并与之连接,并且()
A. 若文件存在,将文件写指针定位于文件尾;若文件不存在,建立一个新文件
B. 若文件存在,将其置为空文件;若文件不存在,打开失败 C. 若文件存在,将文件写指针定位于文件首;若文件不存在,建立一个新文件
D. 若文件存在,打开失败;若文件不存在,建立一个新文件 答案:A
解析:(P199)ios::binary,采用二进制形式,ios::app定位到文件尾部。
10. 构造函数不具备的特征是() A. 构造函数的函数名与类名相同 B. 构造函数可以重载
C. 构造函数可以设置默认参数 D. 构造函数必须指定类型说明 答案:D
解析:(P75)构造函数无返回类型不能继承但可以重载,所以选择D项。
11. 在公有继承的情况下,基类的公有或保护成员在派生类中的访问权限() A. 受限制 B. 保持不变 C. 受保护 D. 不受保护 答案:B
解析:(P132)继承方式的不同派生类成员的权限也不同,采用公有继承,除了私有无法访问外
,公有、保护在派生类中保持不变,所以选择B项。 12. 假定一个类的构造函数为A(int aa,int bb) {a=aa--;b=a*},则执行A x(4,5);语句后 ,x.a和x.b的值分别为() A. 3和15 B. 5和4 C. 4和20 D. 20和5 答案:C
解析:(P75)a=4,因为后减,b的值与a、bb相关,b=4*5=20,而与aa没有任何关系。 13. C++对C语言做了很多改进,即从面向过程变成为面向对象的主要原因是()
A. 增加了一些新的运算符
B. 允许函数重载,并允许设置缺省参数 C. 规定函数说明符必须用原型 D. 引进了类和对象的概念 答案:D
解析:(P29)C++是一面向对象的语言,面向对象的特征,抽象、多态、继承和封装。
14. 在类中说明的成员可以使用关键字的是() A. public B. extern C. cpu
D. register
答案:A 解析:extern用于声明外部变量的。register声明寄存器类型变量。B. void tt(int)=0
C. virtual void tt(int) 无cpu类型。它们都不能声
明类成员。public声明为公有访问权限,所以选择A项。
15. C++语言中所有在函数中定义的变量,连同形式参数,都属于()
A. 全局变量 B. 局部变量 C. 静态变量 D. 函数 答案:B
解析:变量存储类可分为两类:全局变量和局部变量。
(1)全局变量:在函数外部定义的变量称为全局变量,其作用域为:从定义变量的位置开始到
源程序结束。使用全局变量降低了程序的可理解性,软件工程学提倡尽量避免使用全局变量。
(2)局部变量:在函数内部定义的变量称为局部变量,其作用域为:从定义变量的位置开始到
函数结束。局部变量包含自动变量(auto)静态变量(static)以及函数参数。形参不能是静态 的。所以选择B项。
16. 在私有继承的情况下,基类成员在派生类中的访问权限() A. 受限制 B. 保持不变 C. 受保护 D. 不受保护 答案:A
解析:(P132)私有继承下,基类中的公有或保护成员在派生类中也是私有的,所以选择A选项。
17. 使用地址作为实参传给形参,下列说法正确的是() A. 实参是形参的备份 B. 实参与形参无联系 C. 形参是实参的备份 D. 实参与形参是同一对象 答案:D
解析:(P51)地址作为实参,表示实参与形参代表同一个对象。如果实参是数值,形参也是普通
变量,此时形参是实参的备份。所以选择D项。 18. C++的继承性允许派生类继承基类的()
A. 部分特性,并允许增加新的特性或重定义基类的特性 B. 部分特性,但不允许增加新的特性或重定义基类的特性 C. 所有特性,并允许增加新的特性或重定义基类的特性 D. 所有特性,但不允许增加新的特性或重定义基类的特性 答案:A
解析:(P129)派生类有两类成员:一是基类,二是自身类。派生类中的成员不能访问基类中的私
有成员,可以访问基类中的公有成员和保护成员。 19. 对于int *pa[5];的描述,正确的是()
A. pa是一个指向数组的指针,所指向的数组是5个int型元素 B. pa是一个指向某个数组中第5个元素的指针,该元素是int型变量
C. pa[5]表示某个数组的第5个元素的值
D. pa是一个具有5个元素的指针数组,每个元素是一个int型指针 答案:D
解析:(P117)指针数组:数组元素都是相同类型的指针,相同类型的指针是说指针所指向的对象
类型是相同的。例如,语句int *pa[5];定义了一个指针数组。在指针数组的定义中有两个运
算符:*和[],运算符[]的优先级高于*,所以*pa[5]等价于*(pa[5]),pa[5]表示一
个数组,而*表示后面的对象为指针变量,合在一起*pa[5]表示一个指针数组。该数组包含5个
元素,每个元素都是指向int型的指针。所以选择D选项。 20. 以下基类中的成员函数表示纯虚函数的是() A. virtual void tt()=0
D. virtual void tt(int){}
解析:(P173)当在基类中不能为虚函数给出一个有意义的实现时,可以将其声明为纯虚函数,实 现由派生类完成。格式:virtual&函数返回类型说明符&&函数名&(&参数表&)=0;。
二、填空题(本大题共20小题,每小题1分,共20分)请在每小题的空格中填上正确答 案。错填、不填均无分。
1. 单目运算符作为类成员函数重载时,形参个数为___个。 答案:(P189)0
[解析]单目运算符使用成员函数重载可以不用形参,双目运算符使用一个参数。
2. 抽象类中至少要有一个___函数。 答案:(P173)纯虚
[解析]至少有一个纯虚函数的类就称为抽象类,即不能实例化。 3. 设类A有成员函数void f(void);若要定义一个指向类成员函数的指针变量pf来指向f,该 指针变量的声明语句是:___。
答案:(P117)void (A::*pf)(void)=&A::f;
[解析]void(A::*pf)(void)=&A::f;指向成员函数的指针,它相当于两条语句
:void(A::*pf)(void);和pf=&A::f;。 4. 执行下列程序
double a=3.1415926,b=3.14;
cout&&setprecision(5)&&a&&&, &&&setprecision(5)&&b&& 程序的输出结果是___。 答案:3.
[解析]题目设置精度即有效数字都是5,a四舍五入是3.1416,b是3.14。
5. vector类中用于删除向量中的所有对象的方法是___。 答案:(P151)clear()
[解析]向量的使用。返回向量中对象的方法有:front()back()operator[],在向量中删
除对象的方法pop_back erase clear。
6. 重载的运算符保持其原有的___、优先级和结合性不变。 答案:(P183)操作数
[解析]运算符重载时要遵循以下规则:
(1)除了类属关系运算符“.”、成员指针运算符“.*”、作用域运算符“::”、sizeof运算符
和三目运算符“?:”以外,C++中的所有运算符都可以重载。
(2)重载运算符限制在C++语言中已有的运算符范围内的允许重载的运算符之中,不能创建新的 运算符。
(3)重载之后的运算符不能改变运算符的优先级和结合性,也不能改变运算符操作数的个数及 语法结构。
7. 编译时的多态性通过___函数实现。 答案:(P165)重载
[解析]编译多态性,实现的方法主要通过函数的重载或运算符的重载。
8. 基类的公有成员在派生类中的访问权限由___决定。 答案:(P132)访问控制方式或继承方式
9. 假设类X的对象x是类Y的成员对象,则“Y Obj”语句执行时,先调用类___的构造函数。 答案:(P130)X
[解析]派生类中的构造函数的执行顺序,先基类后派生类。 10. 下列程序段的输出结果是___。 cout.setf(ios::showpos); cout&&509.3&& 答案:(P193)+509.3
[解析]输入、输出格式ios::showpos用于输出数据的符号位。 11. 下列程序段的输出结果是___。
包含各类专业文献、高等教育、生活休闲娱乐、外语学习资料、各类资格考试、文学作品欣赏、幼儿教育、小学教育、C++程序设计模拟试题及答案80等内容。 
 C++程序设计 1、声明个 CPU 类,包含等级(rank),频率(frequency) ,电压(voltage)属性,有两个公 有成员函数 run(函数功能:输出“cpu 正在运行” ),stop(函数...  《C++程序设计》试题库(含答案)一、填空题(共 10 题,每题 2 分,共 20 分) 【29 选 10】 1. Qt 是 1994 年成立的总部位于挪威奥斯陆的奇趣科技公司提供...  C++语言程序设计试题试题及答案_理学_高等教育_教育专区。C 语言程序设计试卷 ,C++语言程序设计试题及答案 一、单项选择题(每题 1 分,共 20 分) 1. C 语言规...  C++程序设计题库(182道含答案)_IT认证_资格考试/认证_教育专区。C++程序设计题库 试卷编号:8172 所属语言:C++ 试卷方案:题库 182 道设计题 试卷总分:1820 分...  程序设计C++试题和答案_计算机软件及应用_IT/计算机_专业资料。程序设计Ⅱ(C++语言)期中考试试题班级:___ 学号:___ 姓名:___ 一、简答题(每小题 4 分,共...  C++程序设计及题集(含答案)_电脑基础知识_IT/计算机_专业资料。本学期《程序...编一程序模拟整数加、减、乘、除四则运算。当你在键盘上输入 5+6 后,程序...  大学大一C语言程序设计期末考试试卷及答案_电脑基础知识_IT/计算机_专业资料。C 语言程序设计试卷答卷说明: 1、本试卷共 6 页,答题纸 3 页,4 个大题,35 个...  Visual_C++程序设计-期末试题及答案_学习计划_计划/解决方案_实用文档。面向对象 练习题 Visual C++程序设计-期末试题及 答案一、选择题(每题 1 分,共 5 分) ...  《C语言程序设计》期末考试题及答案_计算机软件及应用_IT/计算机_专业资料。《C语言程序设计》期末考试题及答案
学年第二学期期末考试 2010 级《C ...

我要回帖

更多关于 大发体育投注 的文章

 

随机推荐