QT 4: программирование GUI на С++
Шрифт:
Мы устанавливаем в конструкторе переменную stopped на значение false.
Функция run вызывается для запуска потока. Пока переменная stopped имеет
Функция stop устанавливает переменную stopped на значение true, тем самым указывая функции run на необходимость прекращения вывода текстовых сообщений на консоль. Данная функция может вызываться из любого потока в любое время. В нашем примере мы предполагаем, что присваивание значения переменной типа bool является атомарной операцией. Такое предположение является разумным, учитывая, что переменная типа bool может иметь только два состояния. Позже мы рассмотрим в данном разделе способы применения класса QMutex, гарантирующего атомарность операции присваивания значения переменной.
Класс QThread содержит функцию terminate, которая прекращает выполнение потока, если он все еще не завершен. Функцию terminate не рекомендуется применять, поскольку она может остановить поток в произвольной точке и не позволяет потоку выполнить очистку после себя. Всегда надежнее использовать переменную stopped и функцию stop, как мы уже делали здесь.
Рис. 18.1. Приложение Threads.
Теперь мы рассмотрим способы применения класса Thread в небольшом приложении Qt, которое применяет два потока, А и В, не считая главный поток.
В классе ThreadDialog объявляются две переменные типа Thread и
В конструкторе мы вызываем функцию setMessage для периодического вывода на экран первым потоком буквы «А» и вторым потоком буквы «В».
Когда пользователь нажимает кнопку потока А, функция startOrStopThreadA останавливает поток, если он выполняется, и запускает его в противном случае. Она также обновляет текст кнопки.
Программный код функции startOrStopThreadB очень похож.
Если пользователь выбирает пункт меню Quit или закрывает окно, мы даем команду останова для каждого выполняющегося потока и ожидаем их завершения (используя функцию QThread::wait) прежде, чем сделать вызов CloseEvent::accept. Это обеспечивает аккуратный выход из приложения, хотя в данном случае это не имеет значения.