pure virtual method called. Вот есть у меня базовый класс, пусть будет Base, в котом есть virtual void event_handler(Event &ev) = 0. И есть другой класс, пусть будет Derived, который собственно и содержит реализацию этого метода. Что хочу - позвать из Base класса этот метод, но иногда оно падает с ошибкой как выше.
Я подозреваю это случается потому, что Derived класс не успел выполнить свой конструктор, а Base класс уже позвал его метод (т.к. там еще и std::thread, да). И получается то самое "никогда не вызывайте виртуальные методы из конструктора/деструктора"
Вопрос: как бы это все правильно разрулить ? Может, добавить какой-то atomic флаг который сказал бы, что инициализация прошла, или я вообще не прав тут ? :)
Ну, как вариант вынести инициализацию и старт тредов из конструктора в метод Initialize.
Да, этот вариант сейчас сделал, работает. Но может есть способы проще :)
Имхо это самый простой и понятный способ и есть)
Понял, спасибо )
Лучше тогда сделай статический метод Derive::build, который проинициализирует всё что надо и вернут std::unique_ptr<Base>. Тогда пользоваться будет удобнее (один вызов, вместо двух)
в конструкторе нельзя вызывать виртуальные функции
Похоже на то, да. А разрулить — не зови event_handler(Event &ev) в конструкторе, и всего делов.
Можно. Только не абстрактные в данном классе.
Обсуждают сегодня