C++第二学期期末考试选择题题库(qlu题库,自用)

2024-06-20 21:04

本文主要是介绍C++第二学期期末考试选择题题库(qlu题库,自用),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

又到了期末周,突击一下c++吧@—@

第一次实验 

1、已知学生记录的定义为:
struct student
{
 int no;
 char name[20];
 char sex;
 struct  注意年月日都是结构体,不是student里面的                                
 {
  int year;
  int month;
  int day;
 }birth;
};
struct student s;
假设变量s中的"生日"应是"1988年5月10日",对"生日"的正确赋值语句是 【 正确答案: d】      
(A) year=1988; month=5; day=10;
(B) brith.year=1988; birth.month=5; birth.day=10;
(C) s.year=1988; s.month=5; s.day=10;
(D) s.birth.year=1988; s.birth.month=5; s.birth.day=10; 

2、直接打

已知:
union u_type
{
 int i;
 char ch;
}temp;
执行语句"temp.i=305;"后,temp.ch的值为   【 正确答案: D    

(A)  266  (B)  256  (C)  10  (D)  1

3、设有以下说明语句: 【 正确答案: c
struct strutype
{
 int a;
 float b;
}var;
则下面叙述中错误的是      
(A)  struct是结构类型的关键字
(B)  struct strutype是用户定义的结构类型
(C)  var是用户定义的结构类型名
(D)  a和b都是结构成员名 

(A) struct 是结构类型的关键字 - 正确。在 C 语言中,struct 确实是用来定义结构体类型的关键字。

(B) struct strutype 是用户定义的结构类型 - 正确。这里 struct strutype 定义了一个名为 strutype 的结构体类型。

(C) var 是用户定义的结构类型名 - 错误。var 并不是结构类型名,而是该结构体类型的一个变量名。struct strutype 是结构类型名,而 var 是这个类型的一个实例或对象。

(D) a 和 b 都是结构成员名 - 正确。在结构体 struct strutype 中,a 是一个整型成员,b 是一个浮点型成员。

因此,错误的叙述是 (C)。

4、以下对结构类型变量std1的定义中错误的是  【 正确答案: d     
(A)#define STUDENT struct student
   STUDENT
     {  int num;
        float age;
     } std1;
(B)struct student
     {  int num;
        float age;
     };
   struct student std1;
(C)struct
    {  int num;
       float age;
    } std1;
(D)struct
    {  int num;
       float age;
    } student;
struct student std1;

 这个选项首先定义了一个匿名结构体,并定义了一个名为 student 的变量(注意这里 student 是一个变量名,而不是类型名)。然而,在下一行中,它尝试使用 struct student 来定义 std1,但此时 student 并没有作为一个类型名被定义。因此,struct student std1; 这行代码是错误的,因为编译器不知道 student 是一个结构体类型。

5、

假设sizeof(int)为4,sizeof(char)为1,sizeof(double)为8,已知:
  union
     {
 int i;
 char c;
 double d;
     }test;
则sizeof(test)为  【 正确答案: b    

(A)13;
(B)8;
(C)16;
(D)4;

6、

若有以下说明和语句:
struct student
{
    int age;
    int num;;
}std, *p;
p = &std;
则以下对结构变量 std 中成员 age 的引用方式不正确的是 【 正确答案: d        

(A)   std.age
(B)  p->age
(C)  (*p).age
(D)  *p.age

(A) std.age - 这是正确的。直接通过结构体变量名加.和成员名来访问成员。

(B) p->age - 这是正确的。p是一个指向student结构体的指针,所以可以使用->运算符来访问成员。

(C) (*p).age - 这也是正确的。*p解引用指针p,得到结构体变量std,然后再通过.和成员名来访问成员。

(D) *p.age - 这是不正确的。这里的.运算符优先级高于*运算符,所以p.age首先会被尝试解析,但p是一个指针,不是一个结构体,所以不能使用.来访问成员。正确的做法是先解引用指针,即(*p).age

7、

若有以下说明和语句,则下面表达式中值为1002的是 【 正确答案: d】          
struct student
{
    int age;
    int num;
};
struct student stu[3] = {{1001, 20}, {1002, 19}, {1003, 21}};
struct student *p;
p = stu;

(A)  (p++)->num
(B)  (p++)->age
(C)  (*p).num
(D)  (*++p).age

第二次实验 

1、

2、

第三次实验 

1、为了区分一元运算符的前缀和后缀运算,在后缀运算符进行重载时,额外添加一个参数,其类型是 【 正确答案: c
A void
B char
C int
D float

2、下面关于运算符重载的说法中,错误的是 【 正确答案: a
A 可以对C++所有运算符进行重载
B 运算符重载保持固有的结合性和优先级顺序
C 运算符重载不能改变操作数的个数
D 在运算符函数中,不能使用缺省的参数值

第四次实验 

1、C++流中重载了运算符<<,它是一个 【 正确答案: d】。

(a)用于输出操作的成员函数    (b)用于输入操作的非成员函数

(c)用于输入操作的成员函数    (d)用于输出操作的非成员函数

 第五次实验

1、

有如下类定义:

class base{
public:int x;
protected: int y;
private: int z;
};

派生类采用什么方式继承可以使x成为自己的公有成员 【 正确答案: a】 。

(a)公有继承      (b)保护继承    (c)私有继承    (d)以上三个都对

2、

在公有派生的情况下,有关派生类对象和基类对象的关系的关系,不正确的叙述是 【 正确答案: C
A 派生类的对象可以赋给基类对象
B 派生类的对象可以初始化基类的引用
C 派生类的对象可以直接访问基类中的成员
D 派生类的对象的地址可以赋给指向基类的指针

第六次实验 

1、

私有继承的情况下,允许派生类直接访问的基类成员包括 【 正确答案: B
A 公有成员和私有成员
B 公有成员和保护成员
C 保护成员和私有成员
D 公有成员、私有成员和保护成员 

2、

派生类的对象对其基类成员中 【 正确答案: A】是可以访问的
公有继承中的公有成员
B 公有继承中的保护成员
C 私有继承中的公有成员
D 以上三者都对

3、

下列虚基类的声明正确的是 【 正确答案: A
A class derived:virtual public base
B virtual class derived:public base
C class virtual derived:base
D class derived: base1 virtual

4、在公有派生的情况下,有关派生类对象和基类对象的关系的关系,不正确的叙述是 【 正确答案: C
A 派生类的对象可以赋给基类对象
B 派生类的对象可以初始化基类的引用
C 派生类的对象可以直接访问基类中的成员
D 派生类的对象的地址可以赋给指向基类的指针

5、直接打,看报错位置

#include<iostream>
using namespace std;
class base
{int n;
public:base(int a,int b,int c){n=a;x=b;y=c;}
protected:int x,y;};
class derived:public base
{    
public:int m;derived(int a,int b,int c,int d):base(a,b,c){m=d;}
};
int main()
{derived s(1,2,3,4);//①cout<<s.n<<endl;//②cout<<s.x<<s.y<<endl;//③cout<<s.m<<endl;//④
}

有语法错误的语句是 【 正确答案: B】 。

(a)①②      (b)②③      (c)③④      (d)①④

 6、

class base{int x;
public:base(int n){ x=n;}
};class derived: public base{int y;
public:derived(int a,int b);
};

下列对构造函数derived的定义,正确的是 【 正确答案: A】。

(A) derived::derived(int a,int b):base(a),y(b){}

这个选项是正确的。它首先调用了基类 base 的构造函数,传递了参数 a,然后初始化了 derived 类的成员 y,传递了参数 b

(B) derived::derived(int a,int b):x(a),y(b){}

(C) derived::derived(int a,int b):base(a),derived(b){}

(D) derived::derived(int a,int b):x(a),derived(b){}

7、

class base{int i;
public:void set(int n){ i=n;}int get( )const{ return i; }
};
class derived: protected base{
protected:int j;
public:void set(int m, int n){ base::set(m); j=n;}int get( )const{ return base::get( )+j; }
};

则类derived中保护的数据成员和成员函数的个数是 【 正确答案: C】。

(A)1        (B)2        (C)3        (D)4

第七次实验

1、假定AA为一个类,a为该类私有的数据成员,GetValue( )为该类公有函数成员,它返回a的值,x为该类的一个对象,则访问x对象中数据成员a的格式为(  【 正确答案: D )

(A)  x.a

(B)  x.a()

(C)  x->GetValue()

(D)   x.GetValue( )

 2、

下列关于虚基类的描述中,错误的是(  【 正确答案: C )

(A)  使用虚基类可以消除由多继承产生的二义性

(B)  构造派生类对象时,虚基类的构造函数只被调用一次

(C)  声明 class B:virtual public A 说明类B为虚基类

A作为B的基类时是以虚基类的方式被继承

(D)   建立派生类对象时,首先调用虚基类的构造函数

3、

下列运算符中,不能重载的是 (  【 正确答案: C )

(A)  &&

(B)  !=

(C)  .  

(D)  ->

 4、

下列关于类和对象的叙述中,错误的是(  【 正确答案: A )

(A)  一个类只能有一个对象

(B)  对象是类的具体实例

(C)  类是对某一类对象的抽象

(D)  类和对象的关系是一种数据类型与变量的关系

5、

下列关于类定义的说法中,正确的是(  【 正确答案: A )

(A)  类定义中包括数据成员和函数成员的声明

(B)  类成员的缺省访问权限是protected

(C)  数据成员必须被声明为私有的

(D)  成员函数只能在类体外进行定义

6、

析构函数可以返回(  【 正确答案: D )

(A)  指向某个类的指针

(B)  某个类的对象

(C)  状态信息表明对象是否被正确地析构

(D)  不可返回任何值

7、

设A为自定义类,现有普通函数int fun(A& x)。则在该函数被调用时(  【 正确答案: C )

(A)  将执行复制构造函数来初始化形参x

(B)  仅在实参为常量时,才会执行复制构造函数以初始化形参x

(C)  无需初始化形参x

(D)  仅在该函数为A类的友元函数时,无需初始化形参x

8、

在下面类声明中,关于生成对象不正确的是(  【 正确答案: C )

class point

{ public:

int x;

int y;

point(int a,int b) {x=a;y=b;}

};

(A)  point p(10,2);

(B)  point *p=new point(1,2);

(C)  point *p=new point[2];

(D)  point *p[2]={new point(1,2), new point(3,4)};

C不对是因为缺少无参构造函数,这一点初学者在实际操作的时候也是常犯的错误

9、

下列函数中,(  【 正确答案: C )不能重载。    

(A)  成员函数

(B)  非成员函数

(C)  析构函数

(D)  构造函数

10、

在C++中不能重载的运算符是(  【 正确答案: A)    

(A)  ? :

(B)   +

(C)   -

(D) <=

 11、

下列运算符中,(  【 正确答案: C)运算符不能重载      

(A)  &&

(B)   [ ]

(C)   ::

(D) <<

12、

有如下类定义:class Foo

{

public:

          Foo(int v):value(V){  }     //①

          ~Foo(){}                            //②

private:

          Foo(){}                               //③

          int value=0;                      //④

};

其中存在语法错误的行是: 【 正确答案: D          

(A)  ①

(B)  ②

(C)  ③

(D) ④

13、

下列情况中,不会调用拷贝构造函数的是 【 正确答案: B         
(A)  用一个对象去初始化同一类的另一个新对象时

(B)  将类的一个对象赋值给该类的另一个对象时

(C)  函数的形参是类的对象,调用函数进行形参和实参结合时

(D) 函数的返回值是类的对象,函数执行返回调用时

14、

下面关于new和delete操作符的说法,哪个是不正确的: 【 正确答案: C         
(A)  使用new操作符,可以动态分配全局堆中的内存资源。

(B)  用new申请的数组,必须用delete[] 释放。

(C)  用new申请的空间,即使不调用delete 释放掉,当程序结束时也会自动释放掉。

(D) 执行语句A * p=new A[100] 时, 类A的构造函数会被调用100次。

15、

已知f1和f2是同一类中的两个成员函数,若f1的实现代码体内不能调用f2, 则可能的情况是 【 正确答案: B         
(A)  fl和f2都是静态函数

(B)  fl是静态的,f2不是 

(C)  f1不是静态的,f2是静态的

(D)  fl和f2都不是静态函数

静态成员函数: 

  1. 静态成员函数属于类本身,而不属于类的任何特定对象。
  2. 它们可以直接通过类名来调用,而不需要创建类的对象。
  3. 它们不能访问类的非静态成员(包括非静态成员函数和非静态数据成员),因为它们不关联于类的任何特定对象。

第八次实验

1、

在C++中,用于实现运行时多态性的是 【 正确答案: d
A 内联函数
B 重载函数
C 模板函数
D 虚函数

2、

一个对象所占的内存空间中可以保存下面哪类数据? 【 正确答案: D         
(A)  静态数据成员

(B)  内置函数代码

(C)  所有成员函数的入口地址

(D) 虚函数表的入口地址

 3、

下列哪种函数可以是虚函数: 【 正确答案: D         
(A)  自定义的构造函数

(B)  拷贝构造函数

(C)  静态成员函数

(D) 析构函数

4、

模板对类型的参数化提供了很好的支持,因此 【 正确答案: b

A.类模板的主要作用是生成抽象类

B.类模板实例化时,编辑器将根据给出的模板实参生成一个类

C.在 类模板中的数据成员都具有同样类型

D. 模板中的成员函数都没有返回值

5、

如果一个类至少有一个纯虚函数,那么就称该类为 【 正确答案: a
A 抽象类
B 派生类
C 虚基类
D 以上都不对

6、

下列关于抽象类的说明中不正确的是 【 正确答案: c
A 含有纯虚函数的类称为抽象类
B 抽象类不能被实例化,但可声明抽象类的指针变量
C 抽象类的派生类可以实例化
D 纯虚函数可以被继承

7】

    请将下列程序补充完整,使得输出结果为:

Destructor Derived

Destructor Base

  

#include <iostream>

using namespace std;

class Base

{

  public:

              virtual ~Base()      【 正确答案: virtual ~Base ()】    { cout << "Destructor Base"<< endl; }

};

class Derived : public Base

{

  public:

                       【 正确答案: ~Derived () 或 virtual ~Derived ()】   { cout << "Destructor Derived" << endl; }

};

int main ()

{

    Base *pBase = new Derived;

        delete pBase;

}

这篇关于C++第二学期期末考试选择题题库(qlu题库,自用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079244

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现