У меня есть программа заказа напитков типа. Я пытаюсь реализовать шаблон наблюдателя, чтобы при размещении заказа мобильный телефон / наблюдатель отображал порядок, в основном давая им знать об обновлении.
Я просто не знаю, как это сделать. Если я передаю класс TheOrder в классы порядка update (), я получаю множество ошибок. слишком много сообщений ... update () находится в обозревателе, в мобильном телефоне и в классе TheOrder ..
вот мои классы наблюдателей:
#ifndef _OBSERVER_
#define _OBSERVER_
#include <string>
//#include "TheOrder.h"
namespace CoffeeHouse {
namespace Observers {
//class Subject;
class Observer {
protected: virtual ~Observer() = 0 {
};
public:
// virtual
virtual void update()= 0;
};
} // namespace Observer
} // namespace HeadFirstDesignPatterns
#endif
вот конкретный класс наблюдателя
#ifndef _CELLPHONE1_
#define _CELLPHONE1_
#include <iostream>
using namespace std;
namespace CoffeeHouse {
namespace Observers {
class CellPhone1: public Observer {
public:
std::string _number;
CellPhone1(std::string number){
_number = number;
}
void update()
{
std::cout << "BUZZZZZZZ - CellPhone #" << _number << " your order is ready " << endl;
}
};
} // namespace Observer
} //
#endif
вот предметный класс
#ifndef _SUBJECT_
#define _SUBJECT_
#include "Starbuzz.h"
//#include "Starbuzz2.h"
#include "Observer.h"
#include <list>
#include "Beverage.h"
namespace CoffeeHouse {
namespace Observers {
class Subject {
protected: virtual ~Subject() = 0 {
};
public: virtual void registerObserver( Observer* o ) = 0;
public: virtual void removeObserver( Observer* o ) = 0;
public: virtual void notifyObservers() = 0;
};
} // namespace Observer
}
#endif
вот предмет конкретного класса
#ifndef _THE_ORDER_
#define _THE_ORDER_
#include "Beverage.h"
#include <list>
#include <iostream>
#include "Order.h"
#pragma once;
//class Order;
using namespace CoffeeHouse::Decorator;
namespace CoffeeHouse {
namespace Observers {
class TheOrder : public Subject {
private: mutable std::list< Observer* > _observers;
private: mutable std::list< Order* > _orders;
//public: virtual ~Order() = 0
//public: ~TheOrder();
public: void NewOrder(Beverage* bev, Observer* cellphone)
{
// _orders.push_front(new Order(bev, cellphone));
//_//observers.push_front(new Order(bev));
}
public: void registerObserver( Observer* o ) { assert( o );
_observers.push_back(o);
}
public: void removeObserver( Observer* o ) { assert( o );
_observers.remove(o);
}
public: void notifyObservers() {
for( std::list< Observer* >::iterator iterator = _observers.begin(); _observers.end() != iterator; ++iterator ) {
Observer* observer = *iterator;
observer->update();
}
}
};
//}
} // namespace Observer
} // namespace CoffeeHouse
#endif
вот конкретный класс наблюдателя
#ifndef _CELLPHONE1_
#define _CELLPHONE1_
#include <iostream>
using namespace std;
namespace CoffeeHouse {
namespace Observers {
class CellPhone1: public Observer {
public:
std::string _number;
CellPhone1(std::string number){
_number = number;
}
void update()
{
std::cout << "BUZZZZZZZ - CellPhone #" << _number << " your order is ready " << endl;
}
};
} // namespace Observer
} //
#endif
Основной ()
#include "Starbuzz.h" //just header files
#include "Starbuzz2.h" // just header files
#include "Subject.h"
#include "TheOrder.h"
#include "CellPhone2.h"
#include "CellPhone1.h"
using namespace CoffeeHouse::Decorator;
using namespace CoffeeHouse::Observers;
int main( int argc, char* argv[] )
{
Beverage* beverage2 = new DarkRoast();
beverage2 = new Mocha(beverage2);
beverage2 = new Mocha(beverage2);
beverage2 = new Whip(beverage2);
std::cout << "Current Orders: " << endl;
std::cout << beverage2->getDescription()
<< " $"
<< beverage2->cost()
<< std::endl;
Beverage* beverage3 = new HouseBlend();
beverage3 = new Soy(beverage3);
beverage3 = new Mocha(beverage3);
beverage3 = new Whip(beverage3);
std::cout << beverage3->getDescription()
<< " $"
<< beverage3->cost()
<< std::endl;
delete beverage3;
delete beverage2;
//delete beverage;
Bagel* bagel = new Plain();
std::cout.setf( std::ios::showpoint);
std::cout.precision(3);
std::cout << bagel->getDescription()
<< " $"
<< bagel->cost()
<< std::endl;
Bagel* bagel2 = new Raisen();
bagel2 = new Myhummus(bagel2);
bagel2 = new SesemeSeed(bagel2);
bagel2 = new CreameCheese(bagel2);
std::cout << bagel2->getDescription()
<< " $"
<< bagel2->cost()
<< std::endl;
Bagel* bagel3 = new Onion();
bagel3 = new Myhummus(bagel3);
bagel3 = new SesemeSeed(bagel3);
bagel3 = new CreameCheese(bagel3);
std::cout << bagel3->getDescription()
<< " $"
<< bagel3->cost()
<< std::endl;
TheOrder* orders = new TheOrder();
CellPhone1* cellphone1 = new CellPhone1("1");
orders->registerObserver(cellphone1);
orders->notifyObservers();
TheOrder* order = new TheOrder();
CellPhone1* obj2 = new CellPhone1("3");
order->registerObserver(obj2);
order->notifyObservers();
return 0;
}
Я просто хотел бы отправить заказ в класс cellphone1, чтобы я мог отображать каждый отдельный заказ. Думаю, мне нужно отправить его через функцию обновления.
, потому что в cellphone1 есть наблюдатель, поэтому я хотел бы отобразить там порядок ..
В классе TheOrder есть функция notifyObservers (), мне нужно передать этот указатель? также