7月7日所做典型例题

来源:互联网 发布:淘宝店铺转让骗局 编辑:程序博客网 时间:2024/05/21 14:54

1、下面有关虚函数的描述,说法错误的是?

A、虚函数的作用是实现了继承性

B、虚函数的作用就是实现“动态联编”,也就是在程序的运行阶段动态地选择合适的成员函数

C、和类的静态成员函数与非类的成员函数相比,虚函数的效率较低

D、要正确的实现虚函数,只能用一个基类的指针或者引用来指向派生类对象


答案:A

解析:虚函数的作用是实现了多态,而不是继承性。多态主要有两种形式:静态和多态。静态多态主要实现了函数重载和运算符重载;动态多态主要实现了虚函数,虚函数是动态连编,程序在运行过程中确定调用哪一个函数。

2、

#include "stdio.h"
 
classA
{
public:
    int_a;
    A()
    {
        _a = 1;
    }
    voidprint()
    {
        printf("%d", _a);
    }
};
classB: publicA
{
public:
    int_a;
    B()
    {
        _a = 2;
    }
};
intmain()
{
    B b;
    b.print();
    printf("%d", b._a);
}
请问程序输出:

A、22
B、11
C、21
D、12


答案:D
解析:
因为在继承的时候,允许子类存在与父类同名的成员变量,但是并不覆盖父类的成员变量,他们同时存在。 因为给孩子类中没有定义print函数,所以会按照就近原则去寻找父类中是否有print函数。恰好父类中有这个函数,于是调用父类的print函数b.print(),而这个函数会调用父类的a变量。
在继承中,在虽然子类继承了父类的函数,但父类的函数只能操作父类那个块域的数据,这个题中print函数子类是通过继承父类才拥有该函数,但你要是想让这个函数操作数据它只能操作父类中拥有的数据。


3、代码生成阶段的主要任务是:
A、把高级语言翻译成机器语言
B、把高级语言翻译成汇编语言
C、把中间代码变换成依赖具体机器的目标代码
D、把汇编语言翻译成机器语言

答案;C
解析:源码 ->(扫描)-> 标记 ->(语法分析)-> 语法树 ->(语义分析)-> 标识语义后的语法树 ->(源码优化)-> 中间代码 ->(代码生成)-> 目标机器代码 ->(目标代码优化)-> 最终目标代码。代码生成包括中间代码生成和目标代码生成,这里显然指的是目标代码生成,也就是将(优化过的)中间代码翻译成适合目标机器的目标代码。

4、在C++语言中,下列说法正确的是:
A、inline函数表示编译器一定会将函数体直接插入到调用此函数的地方,这样可以加快程序的运行速度
B、局部变量和全局变量不能重名
C、静态局部变量内存是在运行期分配的,存储在堆栈区
D、C++不是类型安全的语言


答案:D
解析:
A、如果内联函数定义在调用函数的后面,则编译器会将其当作普通函数调用来看,并不会直接插入到调用处。
B、可以重名。
C、局部全局变量存储在全局区,而不是堆栈区。
D、java是类型安全的语言

5、C++中构造函数和析构函数可以抛出异常吗?
A、都不行
B、都可以
C、只有构造函数可以
D、只有析构函数可以

答案:C
解析:
1.不建议在构造函数中抛出异常;
2.构造函数抛出异常时,析构函数将不会被执行,需要手动的去释放内存
3.析构函数不应该抛出异常;
4.当析构函数中会有一些可能发生异常时,那么就必须要把这种可能发生的异常完全封装在析构函数内部,决不能让它抛出函数之外;
5. 析构函数异常相对要复杂一些,存在一种冲突状态,程序将直接崩溃:异常的被称为“栈展开(stack unwinding)”【备注】的过程中时,从析构函数抛出异常,C++运行时系统会处于无法决断的境遇,因此C++语言担保,当处于这一点时,会调用 terminate()来杀死进程。因此,当处理另一个异常的过程中时,不要从析构函数抛出异常, 抛出异常时,其子对象将被逆序析构


多项选择:
6、关于浅复制和深复制的说法,下列说法正确的是:
A、浅层复制:只复制指向对象的指针,而不复制引用对象本身。
B、深层复制:复制引用对象本身。
C、如果是浅复制,若类中存在成员变量指针,修改一个对象一定会影响另外一个对象
D、如果是深拷贝,修改一个对象不会影响到另外一个对象


答案:ABCD
解析:深层拷贝 也叫做深拷贝,个人的理解应该是 拷贝了引用对象的内存,这样就会产出两块不同的内存区,而浅拷贝则是两条或多条指针指向了相同的同一块内存区域。简单的来说就是,在有指针的情况下,浅拷贝只是增加了一个指针指向已经存在的内存,而深拷贝就是增加一个指针并且申请一个新的内存,使这个增加的指针指向这个新的内存,采用深拷贝的情况下,释放内存的时候就不会出现在浅拷贝时重复释放同一内存的错误!


0 0
原创粉丝点击