
BlinCT
Список инициализации дял членов класса
Всем привет.
Появился маленький вопрсо по данной теме, со списком инициализации все понятно, если имеется булевая переменная то : value(false).
Но если например у члена класса надо вызватть функцию, как тогда это записывается?
Например QTimer *timeout, как в списке инициализации записать timeout->stop()?
Спасибо.

We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Donate
Hello, Dear Users of EVILEG!!!
If the site helped you, then support the development of the site financially, please.
You can do it by following ways:
- PayPal
- Yandex.Money
- Bitcoin: 13aqaPG8NZhX3By3he9LtrnHsmvRgsbt95
- Patreon - in Patreon I wrote my targets for reducing of advertisements on the site
Thank you, Evgenii Legotckoi
Например вот такое как правильно инициализировать?
То есть коннект остается в теле конструктора, создание указателя понятно, а вот интервал и запуск.
Привет.
Можешь также оставить в конструкторе класса.
А по поводу timeout->stop(), это должно быт ьв теле конструктора или в список инициализации это можно как то запсать?
Это должно быть там, где предполагает логика программы.
То есть там и тогда, когда таймер нужно остановить. И это может быть в слоте timeoutFired .
Или в любом другом методе.
Какой смысл останавливать таймер в конструкторе, если там же его запускают?
И уж тем более не в списке инициализации, получается, что таймер останавливают раньше, чем он вообще создался.
Лямбда или статический метод. Второе на мой взгляд выглядит лучше.
Остаётся лишь вопрос в другом. Насколько это действительно необходимо, использовать статические методы или лямбды для списка инициализации.
Ну если класс родитель, например, таймер в конструкторе просит.
С тем же результатом можно подобный код добавить в тело конструктора.
То есть здесь вопрос лишь в том, чтобы получить какую-то небольшую оптимизацию при инициализации в ущерб читаемости кода.
Хорошо, статический метод не так перегрузит читаемость, но лямбда неплохо попортит кровь, увеличив сложность понимания. То есть читающий код программист должен будет обладать большим опытом, чем если бы это всё было сделано в теле конструктора.
Я поэтому и написал, действительно ли это нужно. Ну либо я неправильно понял ваш комментарий, Михаил.
Почему не используете новый синтаксис коннекта?
Я только ответил как это можно сделать технически. Статические методы иногда используются для инициализации. Другой пример, константный указатель SomeClass * const ptr; не может быть проинициализирован в теле конструктора. Т.к. в теле идёт уже не инициализация, а присваивание.
Да, я понял. Спасибо. Интересно было Ваше мнение вообще в этом плане.
И ещё у QObject уже есть метод startTimer(). Возможно он вам больше подойдёт, если ваш класс унаследован от QObject. Хотя я предпочитаю использовать QTimer отдельно, как вы это и делаете.
Ну и наконец, если нужно, чтобы таймер сработал только один раз, то у QTimer есть статический метод. QTimer::singleShot(600000, &app, SLOT(quit())); // из документации