Я пытаюсь реализовать пример шаблона посетителя, но у меня проблема с циклическими зависимостями объявлений классов. Когда я делаю предварительное объявление класса Visitor, классы Россия и Англия не знают, что у Visitor есть метод посещения, но когда я продлеваю предварительное объявление класса Visitor для метода accept, мне нужно использовать классы Англия и Россия, но они должны знать, кто Посетитель, потому что они используют этот тип в своем коде. Я пробовал много вариантов упорядочения кода, но полностью провалился. Пожалуйста, помогите мне понять, что нужно С ++ для этого. Спасибо.
#include <cstdio>
#include <vector>
using namespace std;
class Visitor;
class Land {
public:
virtual void accept(const Visitor *v);
};
class England : public Land {
public:
void accept(const Visitor *v) {
v->visit(this);
}
};
class Russia : public Land {
public:
void accept(const Visitor *v) {
v->visit(this);
}
};
class Visitor {
public:
void visit(const England *e) const {
printf("Hey, it's England!\n");
}
void visit(const Russia *r) const {
printf("Hey, it's Russia!\n");
}
};
class Trip {
private:
vector<Land> *l;
public:
explicit Trip(vector<Land> *_l):l(_l) {}
void accept(Visitor *v) {
for (unsigned i = 0; i < l->size(); i++) {
l->at(i).accept(v);
}
}
};
int main() {
England england;
Russia russia;
vector<Land> trip_plan;
trip_plan.push_back(england);
trip_plan.push_back(russia);
trip_plan.push_back(england);
Trip my_trip(&trip_plan);
Visitor me;
my_trip.accept(&me);
return 0;
}
А есть вывод g ++
c++ -ansi -Wall -Wextra -Wconversion -pedantic -Wno-unused-parameter -o vp vp.cc
vp.cc: In member function ‘virtual void England::accept(const Visitor*)’:
vp.cc:40: error: invalid use of incomplete type ‘const struct Visitor’
vp.cc:30: error: forward declaration of ‘const struct Visitor’
vp.cc: In member function ‘virtual void Russia::accept(const Visitor*)’:
vp.cc:47: error: invalid use of incomplete type ‘const struct Visitor’
vp.cc:30: error: forward declaration of ‘const struct Visitor’