![]() |
Есть классы A, и B : public A. Нужно, чтобы в A содержался список указателей на методы B. Известны только прототипы методов, но сколько и какие - не известно. Хотелось бы что-то вроде
A { typedef int(B::*handler)(); map<int,handler> eventmap; public: ... } B : public A { void handler1(); void handler2(); ... } Перевести B::* в A::* нельзя (требование ISO/C++), а в A класс B неизвестен. |
А что если перед объявлением A сказать, что есть такой класс B:
Код:
|
Ещё раз: класс B в A неизвестен. Например:
class Control {...} ... class TrackBar : public Control {...} Contol-у абсолютно пофигу на TrackBar. Но хотелось бы поместить в Control обработчик события, который может не перекрывать TrackBar. Событие может и не обрабатываться, а вставлять пустую виртуальную функцию не хочется. Хочу сделать так: class elink : public pair<UMSG, Handler> { bool operator<(...) } vector<elink> events; ... { ... i = lower_bound(events.begin(), events.end(), message); if (i!=events.end() && i->first==message) { (this->*Handler)(params) } } Это вроде как самая быстрая реакция на виндозные послания. |
Да, я понял. Все портит наследование B : public A.
Цитата:
Цитата:
Вообще Ваша задача решается объявлением еще одного класса - указателя на функцию и его использованием и в классе А и в классе В. Это не так красиво, как хотелось бы, но ИМХО, вариантов больше нет. |
Приятно, что в сети есть отзывчивые люди. С классом-функцией у меня, конечно, ничего не получилось (внутри не удаётся присвоить пресловутый A::* к B::*). Я сделал через union. Код получился овратительный, поэтому буду искать другие варианты. Спасибо, hasherfrog, за содействие; Возникнут какие мысли - подкинь, пожалуюста.
|
Время: 12:54. |
Время: 12:54.
© OSzone.net 2001-