0

我有3节课。

class piesa_a{

protected:

    int id;
    char *tip;
    int pret;

public:
[custructor with/without param, display function - works well each one of it]




class piesa_b:public piesa_a
{

private:
    float lungime;
    bool bw;
public:
[custructor with/without param, display function - works well each one of it]

class piesa_c:public piesa_a
{

    private:
        int nr;
        piesa_b *buf;
    public:
        piesa_c():piesa_a(){nr=0; buf = new piesa_b[nr];}
        piesa_c(int n, piesa_b *bu,int aid, char *tipi, int pretzz):piesa_a(aid,tipi,pretzz) 
        {
            buf = new piesa_b[nr];
            for(int i=0;i<nr;i++)
                buf[i]= bu[i];
        }
    void afisare()
    {

        cout<<nr;

    }

主要我有这个:

piesa_c C(2, H,14,"TIPC",20);


C.afisare();

但这不起作用。我不知道是否正确声明了“buf”,因为问题似乎出在最后一堂课上。为什么?

稍后编辑:整个代码在这里: http: //pastebin.com/nx2FGSfe

现在,我主要有这个

int main(int argc, char** argv) {

    piesa_b *H;
            H = new piesa_b[2];

    piesa_a A(4,"TIPA",120);
    piesa_b B(100,1,3,"TIPA",120);
    H[0]=B;
    H[1]=B;
    piesa_c C(2, H,14,"TIPC",20);

    piesa_a** v = new piesa_a*[3];

    v[0] = &A;
    v[1] = &B;
    v[2] = &C;

    for(int i=0;i<3;i++)
        v[i].afisare();

    return 0;
}

显示函数返回此错误

main.cpp:143:14: error: request for member ‘afisare’ in ‘*(v + ((unsigned int)(((unsigned int)i) * 4u)))’, which is of non-class type ‘piesa_a*’
4

2 回答 2

3

nr未在piesa_c()构造函数中初始化,这意味着它将具有未定义的值。

而不是使用动态分配的数组,std::vector<piesa_b>而是使用 a 。它将处理动态内存分配并在piesa_c复制实例时做正确的事情。使用std::vector还意味着nr可以省略成员变量,因为可以从中获取信息,vector::size()并且std::vector可以将其填充到初始化列表而不是构造函数主体中:

std::vector<piesa_b> buf;

piesa_c(int      n,
        piesa_b *bu,
        int      aid,
        char*    tipi,
        int pretzz) : piesa_a(aid,tipi,pretzz),
                      buf(bu, bu + nr) {}

并在每个元素上调用成员函数buf

// C++11 lambda, otherwise use
// std::vector<piesa_b>::const_iterator.
//
std::for_each(buf.begin(), buf.end(), [](piesa_b& pb) { pb.afisare(); });

如果afisare()不修改,则使其为 const:

void afisare() const
{
}

另外,使用std::string代替char*. 如果您坚持在类中动态分配成员,则需要遵守三规则

于 2013-01-31T13:59:01.553 回答
2

我不确定在这种情况下“不工作”是什么意思,但是当你调用这个构造函数时:

piesa_c C(2, H,14,"TIPC",20);

nr未设置数据成员。它可以有任何适合 int 的值,所以当你用它来初始化一个数组时,你会得到变量和奇怪的结果。

请注意,使用std::vectorandstd::string而不是动态分配的数组和char*.

于 2013-01-31T13:58:44.940 回答