具有派生类的push_back

push_back with derived class

本文关键字:push back 派生      更新时间:2023-10-16

我想创建一个对象数组,并使用某个构造函数。

std::vector<Modul> arrDigOut; 
arrDigOut.push_back(Modul(IDC_CHECK1, this, "GVL.DigOut1", pAddr));

只要DigOut不是派生类,这就可以工作。当我派生它并使用类DigOut时,它失败了:

class Modul
{
protected:
    int         id;
    int         nErr;
    void*       plcVar;
    bool        bDigOut;
    PAmsAddr    pAddr;
    ULONG       lHdlVar;
    CButton*    pBt;
public:
    Modul();
    //Modul(int ID, Cbeckhoff_frontendDlg* pCbeckhoff,void* pVar,PAmsAddr pAdr)
    //{
    //    SetID(ID,pCbeckhoff);
    //    plcVar = pVar;
    //    pAddr = pAdr;
    //};
    int         GetID() { return (id); };
    void*       GetplcVar() { return plcVar; };
    void        SetID(int ID, Cbeckhoff_frontendDlg* pCbeckhoff);
    int         InitCheck(Cbeckhoff_frontendDlg* pCbeckhoff);
    CButton*    GetpBt(){return pBt;};
    void        SetButton( Cbeckhoff_frontendDlg* pCbeckhoff);
};
class DigOut : protected Modul
{
public:
    DigOut();
    DigOut(int ID, Cbeckhoff_frontendDlg* pCbeckhoff,void* pVar,PAmsAddr pAdr)
    {
        SetID(ID,pCbeckhoff);
        plcVar = pVar;
        pAddr = pAdr;
    };
};

这是因为对象切片。你需要有一个指向基类的指针向量或智能指针:

std::vector<Modul*> arrDigOut; 
arrDigOut.push_back(new Modul(IDC_CHECK1, this,"GVL.DigOut1",pAddr));
arrDigOut.push_back(new DigOut());

如果不使用智能指针,请记住释放内存。

当您有一个std::vector<Modul> arrDigOut;并插入派生类型的对象时,它将被切片并成为Modul。对象的Modul部分将复制到向量中,其余部分将丢失。