派生类的构造与析构

派生类的构造与析构,第1张

派生类的构造与析构

派生类和基类的构造函数和析构函数。

构造函数的执行顺序是先执行基类的构造函数,然后是子类的构造函数,然后程序结束时,先执行子类的析构函数,再执行基类的析构函数。也就是说,构造函数和析构函数执行正好相反,先构造的后析构,后构造的先析构。

在派生类构造函数中,只要基类不是使用缺省构造函数都要显式的调用基类的构造函数,给出基类名和参数表。若使用缺省构造函数,则可以不用显式给出基类名及参数表。如果基类没有定义构造函数,则派生类也可以不定义,全部采用系统给定的缺省构造函数。如果基类定义了带有形参表的构造函数时,派生类就应当定义构造函数。

例如这次代码,要求自己定义一个派生类,将输入的数组进行排序。写代码时不需要再重复定义输入输出,因为这些都可以继承基类。只需要自己写一个排序,排序的元素直接使用基类所定义的就可以。在写排序的时候并没有太多困难,因为之前做过很多排序算法,唯一的错误就是一直报派生类没有调用构造函数的错误。然后自己就想在派生类里定义一个构造函数就可以,结果构造完毕之后又显示函数重载的错误,然后通过百度追本溯源,又加深了一遍构造函数与析构函数的定义和规则。原来当对象需要通过基类初始化时,若基类没有带参构造函数,那就会自动调用默认生成的缺省构造函数,若基类定义了带参构造函数,那么必须在继承类显示的调用出来,具体格式如下代码:派生类名():基类名(){};还有就是析构函数不参与对象的消亡,对象所在程序段执行完就会自动消亡,而是在对象消亡时做一些善后工作,比如delete内存。

#include
#include
using namespace std;
class MyArray {
public:
    MyArray(int length);
    ~MyArray();
    void Input();
    void Display(string);
protected:
    int* alist;
    int length;
};
MyArray::MyArray(int leng)
{
    length = leng;
    if (leng <= 0)
    {
        cout << "error length";
        exit(1);
    }
    alist = new int[length];
    if (alist == NULL)
    {
        cout << "assign failure";
        exit(1);
    }
    cout << "MyArray类对象已创建!"<> *p;
}
class SortArray:public MyArray
{
public:
    SortArray(int length):MyArray(length)
         {
        cout << "子类构造函数被调用!" << endl;
    }
    ~SortArray()
    {
        cout << "子类析构函数被调用!" << endl;
    }
    void PX()
    {
        cout << "从小到大排序:" << endl;
        for (int i = 1; i < length; i++)
        {
            for (int j = 0; j < i; j++)
            {
                if (alist[j] > alist[i])
                    swap(alist[i], alist[j]);
            }
        }
        for(int i=0; i 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5659285.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存