第11周 程序阅读——继承和派生(4)

本文分析了一段C++代码的执行结果,重点探讨了基类与派生类构造函数及析构函数的调用顺序,并针对构造函数成员初始化列表中的顺序问题进行了详细解释。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:

阅读程序,请写出这些程序的运行结果

#include <iostream>
using namespace std;
class Part  //部件类
{
public:
    Part();
    Part(int i);
    ~Part();
private:
    int val;
};
Part::Part()
{
    val=0;
    cout<<"调用Part的默认构造函数:"<<val<<endl;
}
Part::Part(int i)
{
    val=i;
    cout<<"调用Part的构造函数: "<<val<<endl;
}
Part::~Part()
{
    cout<<"调用Part的析构函数: "<<val<<endl;
}
class Whole: public Part
{
public:
    Whole();
    Whole(int,int,int,int);
    ~Whole();
private:
    Part one;
    Part two;
    int data;
};
Whole::Whole()
{
    data=0;
    cout<<"调用whole的默认构造函数: "<<data<<endl;
}
Whole::Whole(int p, int i,int j,int k):Part(p),one(j),two(i),data(k)  //问题2
{
    cout<<"调用whole的构造函数: "<<data<<endl;
}
Whole::~Whole()
{
    cout<<"调用whole的析构函数: "<<data<<endl;
}
void f()
{
    Whole w1;
    Whole w2(1,2,3,4);
}
int main()
{
    f();
    return 0;
}

先分析程序的执行结果,在上机时运行程序进行对照,再通过单步执行跟踪程序的运行,达到理解基类、派生类中构造函数、析构函数执行过程的目的。

预计运行结果:

调用Part的默认构造函数:0

调用Part的默认构造函数:0

调用Part的默认构造函数:0

调用whole的默认构造函数:0

调用Part的构造函数:1

调用Part的构造函数:3

调用Part的构造函数:2

调用whole的构造函数:4

调用whole的析构函数:4

调用Part的析构函数:2

调用Part的析构函数:3

调用Part的析构函数:1

调用whole的析构函数:0

调用Part的析构函数:0

调用Part的析构函数:0

调用Part的析构函数:0

实际运行结果:

将Whole类的构造函数(见注释//问题2)改为下面形式,请解释出现的警告信息。

  1. Whole::Whole(int p, int i,int j,int k):  Part(p),two(i),one(j),data(k)  //问题2 

two和one的位置对换使得执行构造函数的时候会发生歧义。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值