BlinCT
BlinCT29. Oktober 2019 07:10

Список инициализации дял членов класса

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

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

14
BlinCT
  • 29. Oktober 2019 07:59

Например вот такое как правильно инициализировать?

    m_timeout = new QTimer(this);
    connect(m_timeout, SIGNAL(timeout()), this, SLOT(timeoutFired()));
    m_timeout->setInterval(2000);
    m_timeout->start();

То есть коннект остается в теле конструктора, создание указателя понятно, а вот интервал и запуск.

    Evgenii Legotckoi
    • 29. Oktober 2019 08:20

    Привет.
    Можешь также оставить в конструкторе класса.

      BlinCT
      • 29. Oktober 2019 08:22

      А по поводу timeout->stop(), это должно быт ьв теле конструктора или в список инициализации это можно как то запсать?

        Evgenii Legotckoi
        • 29. Oktober 2019 08:26

        Это должно быть там, где предполагает логика программы.
        То есть там и тогда, когда таймер нужно остановить. И это может быть в слоте timeoutFired .
        Или в любом другом методе.
        Какой смысл останавливать таймер в конструкторе, если там же его запускают?
        И уж тем более не в списке инициализации, получается, что таймер останавливают раньше, чем он вообще создался.

          МП
          • 29. Oktober 2019 08:27
          • (bearbeitet)

          Лямбда или статический метод. Второе на мой взгляд выглядит лучше.

          static QTimer* initTimer(YourClass* parent)
          {
              auto* timeout = new QTimer(parent);
              QObject::connect(timeout, SIGNAL(timeout()), parent, SLOT(timeoutFired()));
              timeout->setInterval(2000);
              timeout->start();
              return timeout;
          }
          

            Остаётся лишь вопрос в другом. Насколько это действительно необходимо, использовать статические методы или лямбды для списка инициализации.

              МП
              • 29. Oktober 2019 08:36

              Ну если класс родитель, например, таймер в конструкторе просит.

                Evgenii Legotckoi
                • 29. Oktober 2019 08:46
                • (bearbeitet)

                С тем же результатом можно подобный код добавить в тело конструктора.
                То есть здесь вопрос лишь в том, чтобы получить какую-то небольшую оптимизацию при инициализации в ущерб читаемости кода.
                Хорошо, статический метод не так перегрузит читаемость, но лямбда неплохо попортит кровь, увеличив сложность понимания. То есть читающий код программист должен будет обладать большим опытом, чем если бы это всё было сделано в теле конструктора.

                Я поэтому и написал, действительно ли это нужно. Ну либо я неправильно понял ваш комментарий, Михаил.

                  МП
                  • 29. Oktober 2019 08:49

                  Почему не используете новый синтаксис коннекта?

                    МП
                    • 29. Oktober 2019 08:51
                    • (bearbeitet)
                    connect(timer, &QTimer::timeout, this, QOverload<>::of(&YourClass::update));
                    

                      Я только ответил как это можно сделать технически. Статические методы иногда используются для инициализации. Другой пример, константный указатель SomeClass * const ptr; не может быть проинициализирован в теле конструктора. Т.к. в теле идёт уже не инициализация, а присваивание.

                        Я только ответил как это можно сделать технически.

                        Да, я понял. Спасибо. Интересно было Ваше мнение вообще в этом плане.

                          МП
                          • 29. Oktober 2019 09:36

                          И ещё у QObject уже есть метод startTimer(). Возможно он вам больше подойдёт, если ваш класс унаследован от QObject. Хотя я предпочитаю использовать QTimer отдельно, как вы это и делаете.

                            МП
                            • 29. Oktober 2019 10:01
                            • (bearbeitet)

                            Ну и наконец, если нужно, чтобы таймер сработал только один раз, то у QTimer есть статический метод. QTimer::singleShot(600000, &app, SLOT(quit())); // из документации

                              Kommentare

                              Nur autorisierte Benutzer können Kommentare posten.
                              Bitte Anmelden oder Registrieren
                              Letzte Kommentare
                              ИМ
                              Игорь Максимов5. Oktober 2024 07:51
                              Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                              d
                              dblas55. Juli 2024 11:02
                              QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                              k
                              kmssr8. Februar 2024 18:43
                              Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                              Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                              EVA
                              EVA25. Dezember 2023 10:30
                              Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                              Jetzt im Forum diskutieren
                              J
                              JacobFib17. Oktober 2024 03:27
                              добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                              JW
                              Jhon Wick1. Oktober 2024 15:52
                              Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                              КГ
                              Кирилл Гусарев27. September 2024 09:09
                              Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                              F
                              Fynjy22. Juli 2024 04:15
                              при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                              Folgen Sie uns in sozialen Netzwerken