2

オブジェクトの配列を作成し、特定のコンストラクターを使用したいと考えています。

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;
    };
};
4

1 に答える 1

9

これはオブジェクトのスライスによるものです。基本クラスへのポインタまたはスマート ポインタのベクトルが必要です。

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一部がベクターにコピーされ、残りは失われます。

于 2012-07-18T12:07:49.987 に答える