C++填空选择题

上传人:xgs****56 文档编号:9761300 上传时间:2020-04-07 格式:DOC 页数:41 大小:239.50KB
返回 下载 相关 举报
C++填空选择题_第1页
第1页 / 共41页
C++填空选择题_第2页
第2页 / 共41页
C++填空选择题_第3页
第3页 / 共41页
点击查看更多>>
资源描述
C+程序设计模拟试卷(一)一、单项选择题1. 编写C+程序一般需经过的几个步骤依次是()A. 编辑、调试、编译、连接B. 编辑、编译、连接、运行C. 编译、调试、编辑、连接D. 编译、编辑、连接、运行答案:B解析:(P21)经过编辑、编译、连接和运行四个步骤。编辑是将C+源程序输入计算机的过程,保存文件名为cpp。编译是使用系统提供的编译器将源程序cpp生成机器语言的过程,目标文件为obj,由于没有得到系统分配的绝对地址,还不能直接运行。连接是将目标文件obj转换为可执行程序的过程,结果为exe。运行是执行exe,在屏幕上显示结果的过程。2. 决定C+语言中函数的返回值类型的是()A. return语句中的表达式类型B. 调用该函数时系统随机产生的类型C. 调用该函数时的主调用函数类型D. 在定义该函数时所指定的数据类型答案:D解析:(P51)函数的返回值类型由定义函数时的指定的数据类型决定的。A项的表达式的值要转换成函数的定义时的返回类型。3. 下面叙述不正确的是()A. 派生类一般都用公有派生B. 对基类成员的访问必须是无二义性的C. 赋值兼容规则也适用于多重继承的组合D. 基类的公有成员在派生类中仍然是公有的答案:D解析:(P136)继承方式有三种:公有、私有和保护。多继承中,多个基类具有同名成员,在它们的子类中访问这些成员,就产生了二义性,但进行访问时,不能存在二义性。赋值兼容规则是指派生类对象可以当作基类对象使用,只要存在继承关系,所以单继承或多继承都适用。基类中的公有成员采用私有继承时,在派生类中变成了私有成员,所以D项错误。4. 所谓数据封装就是将一组数据和与这组数据有关操作组装在一起,形成一个实体,这实体也就是()A. 类B. 对象C. 函数体D. 数据块答案:A解析:(P39)类即数据和操作的组合体,数据是类的静态特征,操作是类具有的动作。5. 在公有派生类的成员函数不能直接访问基类中继承来的某个成员,则该成员一定是基类中的()A. 私有成员B. 公有成员C. 保护成员D. 保护成员或私有成员答案:A解析:(P133)在派生类中基类的保护或者基类公有都可以直接访问,基类的私有成员只能是基类的成员函数来访问。所以选择A项。6. 对基类和派生类的关系描述中,错误的是()A. 派生类是基类的具体化B. 基类继承了派生类的属性C. 派生类是基类定义的延续D. 派生类是基类的特殊化答案:B解析:(P129)派生类的成员一个是来自基类,一个来自本身,所以派生类是基类的扩展,也是基类的具体化和特殊化,派生类是对基类扩展。B项基类不能继承派生类成员,所以错误。7. 关于this指针使用说法正确的是()A. 保证每个对象拥有自己的数据成员,但共享处理这些数据的代码B. 保证基类私有成员在子类中可以被访问。C. 保证基类保护成员在子类中可以被访问。D. 保证基类公有成员在子类中可以被访问。答案:A解析:(P86)this指针是隐藏的,可以使用该指针来访问调用对象中的数据。基类的成员在派生类中能否访问,与继承方式有关,与this没有关系。所以选择A项。8. 所谓多态性是指 ()A. 不同的对象调用不同名称的函数B. 不同的对象调用相同名称的函数C. 一个对象调用不同名称的函数D. 一个对象调用不同名称的对象答案:B解析:(P167)多态性有两种静态多态性和动态多态性,静态多态性是指调用同名函数,由于参数的不同调用不同的同名函数;动态多态性是指不同对象调用同名函数时,由于对象不同调用不同的同名函数。 多态性肯定具有相同的函数名,所以选择B项。9. 一个函数功能不太复杂,但要求被频繁调用,则应把它定义为 ()A. 内联函数B. 重载函数C. 递归函数D. 嵌套函数答案:A解析:(P59)内联函数特征代码少,频繁调用,执行效率高。重载函数解决统一接口的问题;递归是子程序调用,程序调用要耗费很多空间和时间,循环/迭代都比递归有效率得多,递归只是从形式上,逻辑比较简洁。嵌套函数即反复调用,速度较慢。所以选择A项。10. 下面函数模板定义中不正确的是()A. AB. BC. CD. D答案:A解析:(P147)A项中F是一个返回Q类型的值,而return中用返回类型作为返回值错误。所以选择A项。11. 假设ClassY:publicX,即类Y是类X的派生类,则说明一个Y类的对象时和删除Y类对象时,调用构造函数和析构函数的次序分别为()A. X,Y;Y,XB. X,Y;X,YC. Y,X;X,YD. Y,X;Y,X答案:A解析:(P130)派生类构造函数必须对这三类成员进行初始化,其执行顺序:调用基类构造函数;调用子对象的构造函数;派生类的构造函数体。析构函数在执行过程中也要对基类和成员对象进行操作,但它的执行过程与构造函数正好相反,即对派生类新增普通成员进行清理;调用成员对象析构函数,对派生类新增的成员对象进行清理;调用基类析构函数,对基类进行清理,所以选择A项。12. 适宜采用inline定义函数情况是()A. 函数体含有循环语句B. 函数体含有递归语句C. 函数代码少、频繁调用D. 函数代码多、不常调用答案:C解析:(P59)内联函数具有程序代码少、频繁调用和执行效率高的特征,所以选择C项。13. 假定一个类的构造函数为A(int aa,int bb) a=aa-;b=a*bb;,则执行A x(4,5);语句后,x.a和x.b的值分别为()A. 3和15B. 5和4C. 4和20D. 20和5答案:C解析:(P75)a=4,因为后减,b的值与a、bb相关,b4*5=20,而与aa没有任何关系。14. 在类中说明的成员可以使用关键字的是()A. publicB. externC. cpuD. register答案:A解析:extern用于声明外部变量的。register声明寄存器类型变量。无cpu类型。它们都不能声明类成员。public声明为公有访问权限,所以选择A项。15. 下列不能作为类的成员的是()A. 自身类对象的指针B. 自身类对象C. 自身类对象的引用D. 另一个类的对象答案:B解析:类的定义,如果有自身类对象,使得循环定义,B项错误。在类中具有自身类的指针,可以实现链表的操作,当然也可以使用对象的引用。类中可以有另一个类的对象,即成员对象。所以选择B选项。16. 使用地址作为实参传给形参,下列说法正确的是()A. 实参是形参的备份B. 实参与形参无联系C. 形参是实参的备份D. 实参与形参是同一对象答案:D解析:(P51)地址作为实参,表示实参与形参代表同一个对象。如果实参是数值,形参也是普通变量,此时形参是实参的备份。所以选择D项。17. 下列程序的输出结果是()#include void main()int n3=10,20,30,40,50,60;int (*p)3;p=n;coutp00,*(p0+1),(*p)2endl;A. 10,30,50B. 10,20,30C. 20,40,60D. 10,30,60答案:B解析:如果数组元素都是相同类型的指针,则称这个数组为指针数组。指针数组一般用于处理二维数组。声明的格式为:。p表示指向数组n的行指针。如果将指针的初始化(*p)3=b;地址的等价形式:p+i pi*(p+i)都表示b数组第i+1行的第1个元素的首地址。*(p+i)+jpi+j &pij都表示b数组第i+1行、第j+1列元素的地址。值的等价形式:*(*(p+i)+j) *(pi+j) pij都表示b数组第i+1、第j+1列元素的值。所以题目分别访问p00,p01,p02。18. 在C+中,使用流进行输入输出,其中用于屏幕输入()A. cinB. cerrC. coutD. clog答案:A解析:(P193)(1)标准输入流cin:istream类的对象。(2)标准输出流cout:ostream类的对象。(3)非缓冲型标准出错流cerr:ostream类的对象。(4)缓冲型标准出错流clog:ostream类的对象19. 假定AA为一个类,a()为该类公有的函数成员,x为该类的一个对象,则访问x对象中函数成员a()的格式为()A. x.aB. x.a()C. x-aD. (*x).a()答案:B解析:(P41)对象访问成员的方式为:对象名.成员。指针可以有两种:(*对象指针).成员或者对象指针-成员。A选项是访问数据成员,B项是访问成员函数。20. 关于对象概念的描述中,说法错误的是()A. 对象就是C语言中的结构变量B. 对象代表着正在创建的系统中的一个实体C. 对象是类的一个变量D. 对象之间的信息传递是通过消息进行的答案:A解析:(P37)A对象在C中才有,包括数据和操作两项,而C中的变量只有数据,没有操作。所以A项错误。二、填空题1. C+的流库预定义了4个流,它们是cin、cout、clog和_。答案:(P193)cerr解析cin、cout、clog和cerr分别用于标准输入、输出、标准错误流(缓冲)和标准错误流(非缓冲)。2. 每个对象都是所属类的一个_。答案:(P69)实例解析类是对象的抽象,对象是类的一个实例。3. 在已经定义了整型指针ip后,为了得到一个包括10个整数的数组并由ip所指向,应使用语句_。答案:(P78)int *ip=new int10;解析new用来动态开辟空间。常用来产生动态数组及对象构造函数。4. 函数模板中紧随template之后尖括号内的类型参数都要冠以保留字_。答案:(P145)class解析类模板的使用。template ,也可以引入多参数的如:template 5. 定义类的动态对象数组时,系统只能够自动调用该类的_构造函数对其进行初始化。答案:(P80)无参解析使用new创建对象数组,调用无参构造函数。6. 表达式cout解析指针使用成员有两种方法:“-”指向运算符和“.”成员访问运算符。8. 假如一个类的名称为MyClass,使用这个类的一个对象初始化该类的另一个对象时,可以调用_构造函数来完成此功能。答案:(P80)复制或拷贝复制或拷贝构造函数就是用对象初始化新的对象。9. 对赋值运算符进行重载时,应声明为_函数。答案:(P183)类成员解析运算符重载的方法有友元或者成员函数两种途径,但是赋值运算符只能使用成员函数的方法来实现。10. 如果要把A类成员函数f()且返回值为void声明为类B的友元函数,则应在类B的定义中加入的语句_。答案:(P109)friend void A:f();解析成员函数作为另一个类的友元函数,格式为:friend 返回类型 类名:函数(形参)。11. 下列程序段的输出结果是_。for(i=0,j=10,k=0;i=j;i+,j-=3,k=i+j);coutk;答案:4解析for循环结构,三个表达式的作用,初始化、循环判断条件和循环变量变化。循环执行了三次,k的作用是计算i、j的和。12. String 类的_方法返回查找到的字符串在主串的位置。答案:(P40)find解析string类对象方法的find,查不到字符串,则返回-1。13. int n=0;while(n=1)n+;while循环执行次数是_。答案:无限次解析是赋值运算符,不是关系运算符,且不等0,所以死循环。14. 控制格式输入输出的操作中,函数_是用来设置填充字符。要求给出函数名和参数类型答案:(P195)setfill(char)解析格式控制方法的使用,如setw,setfill等等。15. C+语言支持的两种多态性分别是编译时的多态性和_的多态性。答案:(P167)运行时解析多态性包括静态的(编译时)多态性和动态的(运行时)多态性。16. 设函数sum是由函数模板实现的,并且sum(3,6)和sum(4.6,8)都是正确的函数调用,则函数模板具有_个类型参数。答案:(P61)217. 执行下列代码string str(HelloC+);coutstr.substr(5,3);程序的输出结果是_。答案:(P42)C+解析substr取子字符串,第1个参数表示要截取子串在字符串中的位置,第2个表示取多少个字符。18. 在面向对象的程序设计中,将一组对象的共同特性抽象出来形成_。答案:(P38)类解析类是相似特征的对象的抽象,对象是类的一个实例。19. 定义类动态对象数组时,元素只能靠自动调用该类的_来进行初始化。答案:(P77)无参构造函数解析使用new 创建动态对象数组,不能有参数,所以只能调用无参的构造函数,初始化对象20. 已知有20个元素int类型向量V1,若用V1初始化为V2向量,语句是_。答案:(P151)ector V2(V1);解析采用向量初始化另一个向量的形式:vector name1(name);一、单项选择题1. 静态成员函数没有()A. 返回值B. this指针C. 指针参数D. 返回类型答案:B解析:(P107)静态成员函数是普通的函数前加入static,它具有函数的所有的特征:返回类型、形参,所以使用(P107)静态成员函数,指针可以作为形参,也具有返回值。静态成员是类具有的属性,不是对象的特征,而this表示的是隐藏的对象的指针,因此静态成员函数没有this 指针。静态成员函数当在类外定义时,要注意不能使用static关键字作为前缀。由于静态成员函数在类中只有一个拷贝(副本),因此它访问对象的成员时要受到一些限制:静态成员函数可以直接访问类中说明的静态成员,但不能直接访问类中说明的非静态成员;若要访问非静态成员时,必须通过参数传递的方式得到相应的对象,再通过对象来访问。2. 假定AB为一个类,则执行“AB a(2), b3,*p4;”语句时调用该类构造函数的次数为()A. 3B. 4C. 5D. 9答案:B解析:(P79)a(2)调用1次带参数的构造函数,b3调用3次无参数的构造函数,指针没有给它分配空间,没有调用构造函数。所以共调用构造函数的次数为4。3. 有关多态性说法不正确的是()A. C+语言的多态性分为编译时的多态性和运行时的多态性B. 编译时的多态性可通过函数重载实现C. 运行时的多态性可通过模板和虚函数实现D. 实现运行时多态性的机制称为动态多态性答案:C解析:(P171)多态性分为静态的和动态的。静态通过函数的重载来实现,动态是通过基类指针或基类引用和虚函数来实现的。所以错误的是C项。4. 假定一个类的构造函数为“A(int i=4, int j=0) a=i;b=j;”, 则执行“A x (1);”语句后,x.a和x.b的值分别为()A. 1和0B. 1和4C. 4和0D. 4和1答案:A解析:(P75)带默认的构造函数,对应实参没有值时就采用形参值。调用构造函数时,i=1,不采用默认值,而只有一个参数,j采用默认值0即j=0,因此a=1,b=0,选择A项。5. 类MyA的拷贝初始化构造函数是 ()A. MyA()B. MyA(MyA*)C. MyA(MyA&)D. MyA(MyA)答案:C解析:(P80)复制即拷贝构造函数使用对象的引用作形参,防止临时产生一个对象,A无参构造函数,B是指针作为形参,D项是对象,所以选择C项。6. 在C+中,函数原型不能标识()A. 函数的返回类型B. 函数参数的个数C. 函数参数类型D. 函数的功能答案:D解析:函数的声明,说明函数的参数、返回类型以及函数名,函数体即实现部分决定功能。所以函数的原型不能决定函数的功能。7. 友元关系不能()A. 提高程序的运行效率B. 是类与类的关系C. 是一个类的成员函数与另一个类的关系D. 继承答案:D解析:(P111)友元可以是函数与类的关系即友元函数,也可以类与类的关系即友元类,但友元不能继承,是单向性,且不具有传递性。友元可以访问类中所有成员,提高了访问的方便性。因此选择D项。8. 实现两个相同类型数加法的函数模板的声明是()A. add(T x,T y)B. T add(x,y)C. T add(T x,y)D. T add(T x,T y)答案:D解析:(P63)实现两个相同类型数加法结果应该和操作数具有相同类型。进行加法运算后结果也是和参数具有相同类型,需要返回值。A无返回值时要用void,B形参无类型,C形参y没有类型,所以选择D项。9. 在int a=3,int *p=&a;中,*p的值是()A. 变量a的地址值B. 无意义C. 变量p的地址值D. 3答案:D解析:*p代表引用a变量的值,p代表a的地址值。所以选择D项。10. 下列不是描述类的成员函数的是()A. 构造函数B. 析构函数C. 友元函数D. 拷贝构造函数答案:C解析:(P109)构造函数、析构函数、拷贝构造函数都是特殊的成员函数,友元则不是成员函数。所以选择C项。11. 如果从原有类定义新类可以实现的是()A. 信息隐藏B. 数据封装C. 继承机制D. 数据抽象答案:C解析:(P129)继承指在原有类的基础上产生新类。数据封装即数据和操作组合在一起,形成类。信息的隐藏,通过访问权限来实现。数据抽象,将事物的特征抽象为数据成员或服务。因此选择C项。12. 下面有关类说法不正确的是()A. 一个类可以有多个构造函数B. 一个类只有一个析构函数C. 析构函数需要指定参数D. 在一个类中可以说明具有类类型的数据成员答案:C解析:(P80)构造函数可以有参数、可以重载、因此可以有多个,A项正确。析构函数只有一个不能重载、不能继承,没有返回值,B项正确,C项错误。13. 在函数定义中的形参属于()A. 全局变量B. 局部变量C. 静态变量D. 寄存器变量答案:B解析:形参或函数中定义的变量都是局部变量。在函数外定义的变量是全局变量。形参只能用局部变量,频繁使用的变量可以声明为寄存器变量,形参不能使用静态变量或寄存器变量。14. 下列有关重载函数的说法中正确的是()A. 重载函数必须具有不同的返回值类型B. 重载函数参数个数必须相同C. 重载函数必须有不同的形参列表D. 重载函数名可以不同答案:C解析:(P59)函数的重载必须函数名相同而形参类型或个数不同,与返回值无关。15. this指针存在的目的是()A. 保证基类私有成员在子类中可以被访问B. 保证基类保护成员在子类中可以被访问C. 保证每个对象拥有自己的数据成员,但共享处理这些数据成员的代码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_Screen;ps_Screen可以用_height的地址初始化如下:short Screen:*ps_Screen=&Screen:_height;类成员的指针必须总是通过特定的对象或指向改类型的对象的指针来访问。是通过使用两个指向成员操作符的指针(针对类对象和引用的.*,以及针对指向类对象的指针的-*)。18. 以下基类中的成员函数表示纯虚函数的是()A. virtual void tt()=0B. void tt(int)=0C. 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. 字符型函数答案:C解析:(P108)使用关键字static声明的成员函数就是静态成员函数,静态成员函数也属于整个类而不属于类中的某个对象,它是该类的所有对象共享的成员函数。静态成员函数可以在类体内定义,也可以在类外定义。当在类外定义时,要注意不能使用static关键字作为前缀。由于静态成员函数在类中只有一个拷贝(副本),因此它访问对象的成员时要受到一些限制:静态成员函数可以直接访问类中说明的静态成员,但不能直接访问类中说明的非静态成员;若要访问非静态成员时,必须通过参数传递的方式得到相应的对象,再通过对象来访问。虚函数是非静态的、非内联的成员函数。静态成员函数不能被说明为虚函数。二、填空题1. 假设int a=1,b=2;则表达式(+a/b)*b-的值为_。答案:2解析前缀或表示先使变量值变化,再使用,这和后缀恰恰相反。但是编译cout(+a/b)*b-时,先+a/b值为1,后1*b-,先取b2,结果为2,再让b1。2. 抽象类中至少要有一个_函数。答案:(P173)纯虚解析至少有一个纯虚函数的类就称为抽象类,即不能实例化。3. 一个抽象类的派生类可以实例化的必要条件是实现了所有的_。答案:(P173)纯虚函数的定义解析抽象类只因有纯虚函数,所以不能被实例化,所以派生类要实例化必须对纯虚函数进行定义。4. 下面程序的输出结果为_。#include void main()int num=2,i=6;doi-;num+;while(-i);coutnumendl;答案:5解析dowhile循环,前缀先使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=new int;/ip指向1个未初始化的int型对象(2)给单个对象申请分配内存的同时初始化该对象int *ip;ip=new int(68);/ip指向1个表示为68的int型对象(3)同时给多个对象申请分配内存int *ip;ip=new int5;/ip指向5个未初始化的int型对象的首地址for(int i=0;i5;i+)ipi=5*i+1;/给ip指向的5个对象赋值用new申请分配内存时,不一定能申请成功。若申请失败,则返回NULL,即空指针。因此,在程序中可以通过判断new的返回值是否为0来获知系统中是否有足够的空间供用户使用。7. 由const修饰的对象称为_。答案:(P113)常对象解析使用const关键字说明的成员函数称为常成员函数,使用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_back17. C+语言中如果调用函数时,需要改变实参或者返回多个值,应该采取_方式。答案:(P51)传地址或引用解析传地址即指针,在函数中通过指针修改它指向的变量的值时,实参也就变化了。使用引用,直接修改变量的别名即引用的值,该变量也就随着变化。18. 语句序列ifstream infile;infile.open(“data.dat”);的功能可用一个语句实现,这个语句是_。答案:(P199)ifstream infile(“data.dat”);解析void ifstream:open(const char *fname,int mode=ios:in,intaccess=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的友元函数,则应在类中加入语句_。答案:(P111)friend void B:fun();解析声明成员函数作为另外一个类的友元函数时,使用类作用域运算符:。20. 在编译指令中,宏定义使用_指令。答案:(P6、97)#define解析静态成员是所有对象共享的特征,也就是类的特征。C+程序设计模拟试卷(三)一、单项选择题1. 设有定义int i;double j5;,则10+i+j值的数据类型是()A. intB. doubleC. floatD. 不确定答案: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 * 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和0B. 1和4C. 4和0D. 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项。8. 友元关系不能()A. 提高程序的运行效率B. 是类与类的关系C. 是一个类的成员函数与另一个类的关系D. 继承答案:D解析:(P111)友元可以是函数与类的关系即友元函数,也可以类与类的关系即友元类,但友元不能继承,是单向性,且不具有传递性。友元可以访问类中所有成员,提高了访问的方便性。因此选择D项。9. 语句ofstream f(“TEMP.DAT”,ios:appios: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*bb;,则执行A x(4,5);语句后,x.a和x.b的值分别为()A. 3和15B. 5和4C. 4和20D. 20和5答案:C解析:(P75)a=4,因为后减,b的值与a、bb相关,b4*5=20,而与aa没有任何关系。13. C+对C语言做了很多改进,即从面向过程变成为面向对象的主要原因是()A. 增加了一些新的运算符B. 允许函数重载,并允许设置缺省参数C. 规定函数说明符必须用原型D. 引进了类和对象的概念答案:D解析:(P29)C+是一面向对象的语言,面向对象的特征,抽象、多态、继承和封装。14. 在类中说明的成员可以使用关键字的是()A. publicB. externC. cpuD. register答案:A解析:extern用于声明外部变量的。register声明寄存器类型变量。无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 *pa5;的描述,正确的是()A. pa是一个指向数组的指针,所指向的数组是5个int型元素B. pa是一个指向某个数组中第5个元素的指针,该元素是int型变量C. pa5表示某个数组的第5个元素的值D. pa是一个具有5个元素的指针数组,每个元素是一个int型指针答案:D解析:(P117)指针数组:数组元素都是相同类型的指针,相同类型的指针是说指针所指向的对象类型是相同的。例如,语句int *pa5;定义了一个指针数组。在指针数组的定义中有两个运算符:*和,运算符的优先级高于*,所以*pa5等价于*(pa5),pa5表示一个数组,而*表示后面的对象为指针变量,合在一起*pa5表示一个指针数组。该数组包含5个元素,每个元素都是指向int型的指针。所以选择D选项。20. 以下基类中的成员函数表示纯虚函数的是()A. virtual void tt()=0B. void tt(int)=0C. virtual void tt(int)D. virtual void tt(int)答案:A解析:(P173)当在基类中不能为虚函数给出一个有意义的实现时,可以将其声明为纯虚函数,实现由派生类完成。格式:virtual()=0;。二、填空题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;coutsetprecision(5)a, setprecision(5)bendl;程序的输出结果是_。答案:3.1416,3.14解析题目设置精度即有效数字都是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);cout509.3endl;答案:(P193)+509.3解析输入、输出格式ios:showpos用于输出数据的符号位。11. 下列程序段的输出结果是_。for(i=0,j=10,k=0;i=j;i+,j-=3,k=i+j);coutk;答案:4解析for循环结构,三个表达式的作用,初始化、循环判断条件和循环变量变化。循环执行了三次,k的作用是计算i、j的和。12. C中ostream的直接基类_。答案:(P193)ios解析istream和ostream的直接基类是ios。13. int n=0;while(n=1)n+;while循环执行次数是_。答案:无限次解析是赋值运算符,不是关系运算符,且不等0,所以死循环。14. C+中有两种继承:单继承和_。答案:(P138)多继承解析单继承和多继承,多继承即有多个基类。15. 在C+中,利用向量类模板定义一个具有10个int的向量A,其元素均被置为1,实现此操作的语句是_。答案:(P151)vectorA(10,1)解析定义向量列表vectorA(10,1),使用两个参数,10表示长度,1表示数值。16. vector类中向向量尾部插入一个对象的方法是_。答案:(P157)push_back17. C+语言中如果调用函数时,需要改变实参或者返回多个值,应该采取_方式。答案:(P51)传地址或引用解析传地址即指针,在函数中通过指针修改它指向的变量的值时,实参也就变化了。使用引用,直接修改变量的别名即引用的值,该变量也就随着变化。18. 若函数的定义处于调用它的函数之前,则在程序开始可以省去该函数的_语句。答案:声明解析函数使用有两部分:声明和定义。定义在前,可以无声明;但函数定义在后,调用在前的话,需要先声明函数的原型。19. 在C+中有两种参数传递方式:传值和_。答案:(P51)传引用解析(1)传值调用又分为数据传值调用和地址传值调用。(2)引用调用是将实参变量值传递给形参,而形参是实参变量的引用名。引用是给一个已有变量起的别名,对引用的操作就是对该引用变量的操作。20. 将指向对象的引用作为函数的形参,形参是对象的引用,实参是 _。答案:(P53)对象名解析实参与形参类型要一致,形参是对象的引用,实参应该是对象名。C+程序设计模拟试卷(四)一、单项选择题1. 当一个类的某个函数被说明为virtual时,该函数在该类的所有派生类中()A. 都是虚函数B. 只有被重新说明时才是虚函数C. 只有被重新说明为virtual时才是虚函数D. 都不是虚函数答案:A解析:(P170)在基类声明为virtual的函数为虚函数,在派生类中只要有相同的函数(函数名相同、返回值相同、形参类型和个数相同)即使不用virtual说明,也都是虚函数。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解析
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 解决方案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!