![]() |
Здравствуйте, гость ( Вход | Регистрация )
![]() |
Гость_Артем_* |
![]()
Сообщение
#1
|
Гости ![]() |
Здравствуйте, уважаемые форумчане.
Есть задача написать кросплатформенную динамическую библиотеку, внутри которой задействованы многопоточность и сетевые взаимодействия. Конечно, qt привлекает своим функционалом, стабильностью, легкостью разработки и тд. Перечислять плюсы можно долго. Однако разрабатываемая бибилиотека должна линковаться к любым приложениям, независимо от того используют ли они qt или нет. И в этом загводка. Для работы Qt требуется объект QApplication или QCoreApplication, которые создают петлю событий, обрабатывают события от ОС и др источников, запускают обработку очереди событий и тд. Этот объект создается в main(). Если приложение, основано на qt, то все в порядке. А если нет.. Где его создавать и возможно ли это? Можно ли сделать такую библиотеку? Заранее спасибо! |
|
|
![]() |
Iron Bug |
![]()
Сообщение
#2
|
![]() Профессионал ![]() ![]() ![]() ![]() ![]() Группа: Модератор Сообщений: 1611 Регистрация: 6.2.2009 Из: Yekaterinburg Пользователь №: 533 Спасибо сказали: 219 раз(а) Репутация: ![]() ![]() ![]() |
мне что-то стал интересен этот вопрос. я не юзаю Qt, но не отрицаю потенциальной возможности, что она может пригодиться когда-нибудь. а совместимость меня всегда интересовала.
в документации написано, что QApplication должен создаваться именно в главном потоке приложения, но вот тут есть статья, как упихать QApplication в поток: http://qt-project.org/wiki/boost_thread_qt_application то есть, можно сделать это упихивание прямо в самой библиотеке и создавать поток с QApplication при загрузке библиотеки, например. а потом, как в статье написано, хитро форвардить сообщения, обманывая Qt, будто она работает в основном потоке. вряд ли такая реализация будет мешать основному приложению. я навскидку не вижу тут проблем. |
|
|
![]() ![]() ![]() |
![]() |
|
Текстовая версия | Сейчас: 20.7.2025, 4:35 |