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
?