错误:无效使用不完整的结构体Subject;错误:结构体Subject的前向声明。

4

我从一个模板类继承。当我在teacher类中进行输入时,我希望能够在subject类中进行输入,反之亦然。 但是我遇到了错误,请看:Invalid use of incomplete type struct Subect;

void addSubject(Subject *s) {
            this->addReference(s);
            s->addReference(this); when I comment this line the it compiles without errors, but I cannot insert into Subject 

        }

我的全部代码如下

#include <iostream>
#include <stdlib.h>
#include <vector>

using namespace std;
class Subject;


template <class T>
class abstractReference {


    vector<T*> list;
    public:
    string code;
        void addReference(  T*);
        void delReference(  T*);
        bool hasReference(  T*);
        T * getReference(int );
};

template <class T>
void abstractReference<T>::addReference(T* ref) {
    list.push_back(ref);
    //ref->addReference(this);
}

template <class T>
void abstractReference<T>::delReference(T* ref) {
    int i;
    for (i=0; i<list.size(); i++) {
        if (list[i]== ref) list.erase(i);
    }

}

template <class T>
bool abstractReference<T>::hasReference( T* ref) {
  if (list.size() == 0) return false;
  int i;
  for (i=0; i<list.size(); i++) {
      if (list[i] == ref) return true;
  }
  return false;
}

template <class T>
T* abstractReference<T>::getReference(int i) {
    if (i < 0 || i > list.size()) return NULL;
    return list[i];
}

class Teacher : public abstractReference<Subject> {

    string fname;
    string lname;
    float  sal;
public:
    Teacher(string c, string fn, string ln, float s): fname(fn), lname(ln), sal(s) {
    }
    Teacher() {sal =0; fname=""; lname="";}
    void setInfo(string c, string fn, string ln, float s=0.00) {
        code=c;
        fname = fn;
        lname = ln;
        sal = s;
    }

    string getName() {
        return fname + " " + lname;
    }

    float getSal() {
        return sal;
    }

    void addSubject(Subject *s) {
        this->addReference(s);
        s->addReference(this);

    }

    void delSubject(Subject *s) {

    }

};

class Subject : public abstractReference<Teacher> {
  string title;
public:
  Subject(string c=NULL, string t=NULL) {
      title = t;

  }
  string getTitle() {
      return title;
  }
};

main() {
    Teacher *t;
    t = new Teacher("J109", "Dexter", "McConnell",15000);
    Subject *s, *s1, *s2;
    s= new Subject("E001", "English");
    s1= new Subject("M001", "Maths");
    s2= new Subject("s001", "Science");

    t->addSubject(s);
    t->addSubject(s1);

    cout << "Has Reference " << t->hasReference(s2) << endl;
    cout << "Done..." << endl;
    cout << t->getReference(1)->getTitle() << endl;
}
2个回答

2
问题在于编译器无法理解类型为Subject的对象,可能是因为你只进行了前向声明或忘记包含定义它的头文件。
结果就是对于编译器来说,Subject是一个不完整的类型,无法执行任何需要了解Subject布局的操作,调用它的成员函数就是其中之一。
解决方法是:在源cpp文件中,你应该包含定义Subject的头文件。
void addSubject(Subject *s)

如果你没有多个文件,请确保在定义函数addSubject()之前定义类Subject


1

当编译器尝试编译类Teacher时,类Subject还没有被定义,只被声明。因此,编译器不知道Subject中存在哪些方法。

我的建议是将函数体移动到下面Subject定义之后。

像这样:

class Teacher : public abstractReference<Subject> {
    // ...

    void addSubject(Subject *s);

    // ...
};

class Subject : public abstractReference<Teacher> {
    // ...
};

void Teacher::addSubject(Subject *s) {
    // ...
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接