我有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*’
答案 0 :(得分:3)
nr
未在piesa_c()
构造函数中初始化,这意味着它将具有未定义的值。
而不是使用动态分配的数组而不是std::vector<piesa_b>
。它将处理动态内存分配,并在复制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*
。如果您坚持在类中动态分配成员,则需要遵守rule of three。
答案 1 :(得分:2)
我不确定“不工作”在这种情况下是什么意思,但是当你调用这个构造函数时:
piesa_c C(2, H,14,"TIPC",20);
未设置数据成员nr
。它可以具有适合int的任何值,因此当您使用它来初始化数组时,您将获得变量和奇怪的结果。
请注意,使用std::vector
和std::string
代替动态分配的数组和char*
,可以省去很多麻烦。