面向对象多态性

今天下午面向对象考试,第一道程序题,在这里记录一下代码的理解。

程序代码:

#include <iostream>
using namespace std;
class A{
public:
    A()
    {
        cout << "调用A类构造函数." << endl;
    }
    void fun1()
    {
        cout << "A::fun1()." << endl;
    }
    virtual void fun2()
    {
        cout << "A::fun2()." << endl;
    }
};

class B: public A
{
public:
    B()
    {
        cout << "调用B类构造函数." << endl;
    }
    void fun1()
    {
        cout << "B::fun1()." << endl;
    }
    virtual void fun2()
    {
        cout << "B::fun2()." << endl;
    }
};
int main()
{

    A a, b;
    B c;
    A *p = new B();
    b = c;
    a.fun1(); a.fun2();
    b.fun1(); b.fun2();
    c.fun1(); c.fun2();
    p->fun1(); p->fun2();
    return 0;
}

运行结果:

调用A类构造函数.
调用A类构造函数.
调用A类构造函数.
调用B类构造函数.
调用A类构造函数.
调用B类构造函数.
A::fun1().
A::fun2().
A::fun1().
A::fun2().
B::fun1().
B::fun2().
A::fun1().
B::fun2().
Press any key to continue

总结:

构造函数在声明类对象时就被调用: A a, b; // 依次调用A和A的构造函数;
派生类B要先调用基类构造函数再调用自身构造函数: B c; // 依次调用A和B的构造函数;
new动态分配内存仍然调用相应的构造函数: A *p = new B(); // 父类指针指向子类对象,多态体现
b = c; // 派生类对象赋值给基类对象
a.fun1(); a.fun2(); // 不是多态,调用A类函数
b.fun1(); b.fun2(); // 调用基类构造函数,只有指针和引用才能调用多态
c.fun1(); c.fun2(); // 不是多态,调用B类函数
p->fun1(); p->fun2(); // 重载A的方法fun1(),由于基类的fun2()是虚函数,所以调用重写函数fun2()

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值