Russian Qt Forum

Qt => Пользовательский интерфейс (GUI) => Тема начата: DarkHobbit от Июль 13, 2018, 11:37



Название: QMessageBox из конструктора
Отправлено: DarkHobbit от Июль 13, 2018, 11:37
Доброй пятницы.
Сейчас ковыряю _чужой_ Qt/C++ код, в котором то и дело из конструкторов разных классов вызывается QMessageBox::critical, а то и QMessageBox::information. И меня гложет сомнение: а такое вообще допустимо? Нет, я не про разделение логики и UI, оно-то как раз где-то оправдано, а где-то нет.
Я про то, что вроде бы в конструкторах в принципе не рекомендуют писать код, который может "зависнуть" на неопределённое время. Или я чего-то путаю?
Да, вопрос, возможно, даже не столько про Qt, сколько про хороший тон в C++, но QMessageBox может добавлять свою специфику.


Название: Re: QMessageBox из конструктора
Отправлено: ViTech от Июль 13, 2018, 11:57
И что происходит после вызова QMessageBox::critical? Можно кусок кода показать, прям интересно :). Хотя при написании кода "в формах" может быть всё что угодно.

Лично я бы в конструкторах остерегался какие-либо окна показывать :).


Название: Re: QMessageBox из конструктора
Отправлено: Igors от Июль 14, 2018, 07:15
Нет, я не про разделение логики и UI, оно-то как раз где-то оправдано, а где-то нет.
В один прекрасный день возникает необходимость "нужна версия приложения с командной строкой". Или данный класс потребовался для использования в таком приложении. Достаточно пережить хотя бы один такой случай - и никаких "где-то" уже не будет  :)

И меня гложет сомнение: а такое вообще допустимо?
Да, напр хотелось сразу показать ошибку которую необходимо исправлять. Что-то типа Q_ASSERT(0). А прокладку писать было лень - вот и влепил MessageBox.



Название: Re: QMessageBox из конструктора
Отправлено: Racheengel от Июль 20, 2018, 02:02
тут еще вопрос в реализации этого разделения.  Например,  в конструкторе можно вызвать что то типа абстрактного MessageManager::showMessage (blabla), которая будет уже  в конкретной прилинковываемой из гуи-либы реализации, например,  сделана в виде враппера над QMessageBox, либо в виде нотификатора, либо еще как.


Название: Re: QMessageBox из конструктора
Отправлено: DarkHobbit от Июль 25, 2018, 14:55
И что происходит после вызова QMessageBox::critical? Можно кусок кода показать, прям интересно :)
Код там довольно монструозный, но если в двух словах - там устанавливается флаг ошибки и конструктор завершается. Потом вызывающий класс этот флаг смотрит.
В принципе, если бы вместо флага (а то и вместе с ним) заполнялась строка с сообщением об ошибки, а уже где-то вне класса это сообщение выводилось - у меня бы вопросов и не было, тогда и message box в классе был не нужен...
Просто одно дело, если я человека буду убеждать переписывать код на основании того, что это некрасиво и немножко другое - на основании того, что это вызывает серьёзные проблемы.