YS
Size: a a a
AR
pure virtual method called. Вот есть у меня базовый класс, пусть будет Base, в котом есть virtual void event_handler(Event &ev) = 0. И есть другой класс, пусть будет Derived, который собственно и содержит реализацию этого метода. Что хочу - позвать из Base класса этот метод, но иногда оно падает с ошибкой как выше.Derived класс не успел выполнить свой конструктор, а Base класс уже позвал его метод (т.к. там еще и std::thread, да). И получается то самое "никогда не вызывайте виртуальные методы из конструктора/деструктора"Derive::build, который проинициализирует всё что надо и вернут std::unique_ptr<Base>. Тогда пользоваться будет удобнее (один вызов, вместо двух)YS
Derive d;
d.init();
d.do_something(); // это тоже pure virtual
Derive штук 10, с разными реализациями. В случае с Derive::build мне нужно будет в каждой новой реализации добавить вот этот build. Или я что-то не так понял ? :)DU
Derive d;
d.init();
d.do_something(); // это тоже pure virtual
Derive штук 10, с разными реализациями. В случае с Derive::build мне нужно будет в каждой новой реализации добавить вот этот build. Или я что-то не так понял ? :)virtual?YS
virtual?Base, который создает поток (std::jthread) и содержит некоторую логику (типа, предварительной настройки, коннекторы, etc). И дальше есть разные классы, которые реализуют event_handler(), и этот метод вызывается из Base класса (его потока). Вообще, сама задача в том, что бы на каждую сущность был свой обработчик событийYS
AR
init у тебя тоже виртуальный?AF
pure virtual method called. Вот есть у меня базовый класс, пусть будет Base, в котом есть virtual void event_handler(Event &ev) = 0. И есть другой класс, пусть будет Derived, который собственно и содержит реализацию этого метода. Что хочу - позвать из Base класса этот метод, но иногда оно падает с ошибкой как выше.Derived класс не успел выполнить свой конструктор, а Base класс уже позвал его метод (т.к. там еще и std::thread, да). И получается то самое "никогда не вызывайте виртуальные методы из конструктора/деструктора"AF
Base, который создает поток (std::jthread) и содержит некоторую логику (типа, предварительной настройки, коннекторы, etc). И дальше есть разные классы, которые реализуют event_handler(), и этот метод вызывается из Base класса (его потока). Вообще, сама задача в том, что бы на каждую сущность был свой обработчик событийAF
YS
AF
YS
AF
AF
YS
IZ
pure virtual method called. Вот есть у меня базовый класс, пусть будет Base, в котом есть virtual void event_handler(Event &ev) = 0. И есть другой класс, пусть будет Derived, который собственно и содержит реализацию этого метода. Что хочу - позвать из Base класса этот метод, но иногда оно падает с ошибкой как выше.Derived класс не успел выполнить свой конструктор, а Base класс уже позвал его метод (т.к. там еще и std::thread, да). И получается то самое "никогда не вызывайте виртуальные методы из конструктора/деструктора"IZ
virtual?