我想知道父函数内派生类对象的大小。在我的情况下,父函数是虚函数,因此我不能使用sizeof(子类名称),而必须基于传递的对象来动态决定。下面是代码片段。我在父类的PrintBalance()中使用了sizeof(* this),这将不起作用。我需要类似的东西。我从覆盖的子类中显式调用父类函数。

class Account
{
protected:
    int var1;
    int var2;
    double m_balance;

    public:

    Account( double d )
    {

        m_balance = d;
    }

    virtual double GetBalance()
    {
        return m_balance;
    }
    virtual void PrintBalance()
    {
        cout<<"size in Parent= "<< sizeof(*this)<<endl;
    }
private:

};

class CurrentAccount : public Account
{
    int var3;
    int var4;
public:
    CurrentAccount(double d) : Account(d) {}

    void PrintBalance()
    {
        Account::PrintBalance();
        cout<<"size in Derived = "<< sizeof(*this)<<endl;
        cout << "Current account balance: " << GetBalance() << endl;
    }
};

int main()
{
    CurrentAccount cAcc(1000);
    CurrentAccount *pCurrent = &cAcc ;
    pCurrent->PrintBalance();
    pCurrent->GetBalance();
}

最佳答案

您需要在基类中使用一个虚方法,并在所有派生类中将其覆盖,并返回该类/类型的大小。

class Account
{
public:
    //....
    virtual size_t GetSizeOf() const
    {
        return sizeof(*this);
    }
    //....
    virtual void PrintBalance()
    {
        std::cout << "size in Parent= " << this->GetSizeOf() << std::endl;
    }
    //...
};

class CurrentAccount : public Account
{
public:
    //...
    size_t GetSizeOf() const override
    {
        return sizeof(*this);
    }
    //...
    void PrintBalance() override
    {
        Account::PrintBalance();
        std::cout << "size in Derived = " << this->GetSizeOf() << std::endl;
        // ...
    }
};


因此,它应该从两种方法-http://coliru.stacked-crooked.com/a/37177e4e6e899090中打印相同的尺寸。



更新

要从基础打印所有派生类的成员,您需要一个虚拟方法,该方法允许派生扩展基础。

示例1:使用重写打印派生类的成员:

class Account
{
protected:
    //....
    virtual void DoPrint() const
    {
        std::cout << "print Account's members" << std::endl;
    }
public:
    //....
    void PrintBalance()
    {
        //std::cout << "size in Parent= " << this->GetSizeOf() << std::endl;
        DoPrint();
    }
};

class CurrentAccount : public Account
{
protected:
    //...
    void DoPrint() const override
    {
        Account::DoPrint();
        std::cout << "print CurrentAccount's members" << std::endl;
    }
};


您还可以更改基础以使用字典,甚至使用打印回调列表。

示例2:打印派生类的成员而不重写:(http://coliru.stacked-crooked.com/a/56402cff02a922d2):

#include <functional>
#include <vector>
#include <iostream>

// not using namespace std;

class Account
{
protected:
    int var1 = 1;
    int var2 = 2;
    double m_balance = 3.0;
public:
    std::vector<std::function<void()>> printers;  // Could be made static and pass `this` and as parameter

    Account()
    {
        printers.emplace_back([this]() {
            std::cout << "var1= "<< var1 << "\n"
                      << "var2= "<< var2 << "\n"
                      << "m_balance= "<< m_balance << std::endl;
        });
    }
    //....
    void PrintBalance()
    {
        for ( const auto& p : printers )
        {
            p();
        }
    }
    //...
};

class CurrentAccount : public Account
{
protected:
    int var3 = 4;
    int var4 = 5;
public:
    CurrentAccount(): Account() {
        printers.emplace_back([this]() {
            std::cout << "var3= "<< var3 << "\n"
                      << "var4= "<< var4 << std::endl;
        });
    }
    //...
};

关于c++ - 在父函数中获取子对象的大小,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48446682/

10-12 14:56
查看更多