Http и потоки, Ищу исходники |
Здравствуйте, гость ( Вход | Регистрация )
Http и потоки, Ищу исходники |
BRE |
7.10.2009, 13:03
Сообщение
#11
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
BRE, то, что вы предлагаете - очень опасная практика. Начнут прокачиваться сообщения, т.е. вызываться слоты\обработчики, которые в данный момент времени (посреди работы функции) вызываться совершенно не должны. Как ты себе это представляешь? Какие не нужные слоты начнут отрабатывать посреди работы этой функции. Можно по-подробней. Желательно с примерами. Если этот код будет выполняться в отдельном потоке, то и очередь сообщений будет использоваться этого потока. Кстати, не имеет значения что использовать QHttp или QNetworkAccessManager. Сообщение отредактировал BRE - 7.10.2009, 13:06 |
|
|
rnd |
7.10.2009, 13:18
Сообщение
#12
|
Студент Группа: Участник Сообщений: 54 Регистрация: 22.7.2009 Пользователь №: 930 Спасибо сказали: 1 раз(а) Репутация: 0 |
Как ты себе это представляешь? Какие не нужные слоты начнут отрабатывать посреди работы этой функции. Можно по-подробней. Желательно с примерами. В смысле какие слоты? Обычные слоты, естественно emit которым был сделан из другого потока. Да и вообще, начнут вызываться все обработки - неважно слот, метаколл или эвент. Если пример еще нужен - могу привести. Кстати, не имеет значения что использовать QHttp или QNetworkAccessManager. Как оказалось - имеет, QNetworkAccessManager не виснет в WaitForMultipleObject, почему различия - выяснять не стал |
|
|
BRE |
7.10.2009, 13:29
Сообщение
#13
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
В смысле какие слоты? Обычные слоты, естественно emit которым был сделан из другого потока. Да и вообще, начнут вызываться все обработки - неважно слот, метаколл или эвент. Если пример еще нужен - могу привести. Конечно нужны примеры. Какие ненужные слоты начнут выполняться? По-подробней. выяснять не стал Зря, что не стал. Ты считаешь, что при таком коде ненужные слоты вызываться не будут:
а при таком будут?
|
|
|
rnd |
7.10.2009, 13:30
Сообщение
#14
|
Студент Группа: Участник Сообщений: 54 Регистрация: 22.7.2009 Пользователь №: 930 Спасибо сказали: 1 раз(а) Репутация: 0 |
Ну смотри, допустим в очереди лежит два сообщения - на вызов Class1::slot1 и Class1::slot2. Вызывается slot1() - объект переходит в несогласованное состояние. Начинаем прокачку сообщений - сразу вызыватеся slot2, т.е. колл-стек такой:
---------------- slot2() ... slot1() ... ----------------- Поскольку объект в несогласованном состоянии (выполнение slot1 еще не закончилось) - ахтунг! Зря, что не стал. За это не платят:) |
|
|
BRE |
7.10.2009, 13:51
Сообщение
#15
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
Ну смотри, допустим в очереди лежит два сообщения - на вызов Class1::slot1 и Class1::slot2. Вызывается slot1() - объект переходит в несогласованное состояние. Начинаем прокачку сообщений - сразу вызыватеся slot2, т.е. колл-стек такой: Мне лучше на примере кода показать. Откуда взялись сообщения, кто их туда положил? Вообще, как ты себе все это представляешь. Продублирую сообщение. Вот примерный код двух разных потоков. Что бы разговор был более предметным. Ты считаешь, что при таком коде ненужные слоты вызываться не будут:
а при таком будут?
Где и какие ненужные сообщения/сигналы/слоты будут вызываться? Сообщение отредактировал BRE - 7.10.2009, 13:37 |
|
|
rnd |
7.10.2009, 21:33
Сообщение
#16
|
Студент Группа: Участник Сообщений: 54 Регистрация: 22.7.2009 Пользователь №: 930 Спасибо сказали: 1 раз(а) Репутация: 0 |
Давай отвлечемся от QNetworkAccessNanager - он тут совершенно не при чем сейчас
Смотри, есть два потока, в первом крутится obj1, во втором obj2: Thr1 | Thr2 ------ ------ Obj1 | Obj2 Первый поток эмитит два сигнала sig1, sig2 объекту, который находится во втором потоке. Obj1 ->sig1->Obj2 Obj1 ->sig2->Obj2 Соответствующие слоты(slot1, slot2) не вызываются напрямую, а в очередь Thr2 кладутся сообщения для вызова этих слотов. Дальше, Thr2 извлекает очередное сообщение, видит что это вызов слота slot1 - и вызывает его. Объект Obj2 переходит в несогласованное состояние. Внутри слота slot1 мы начинаем прокачивать сообщения (loop.exec()), Thr2 извлекает следующие сообщение из очереди - видит что это вызов слота slot2 и дергает его - опа приехали, еще не выйдя из slot1 уже запустили slot2! Callstack: ---------- slot2() ..... slot1() .... ------------ Естественно, вместо вызова слотов могут быть любые обработчики. Для того чтобы решить эту проблему - и создается дополнительный поток - Thr3. В него помещается объект и сообщения этот объект получает в нем. А вызывающие поток ждет окончания Thr3 НЕ прокачивая при этом свои сообщения. |
|
|
BRE |
7.10.2009, 22:09
Сообщение
#17
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
Тебе не кажется, что это немного надуманный пример.
Я привел тебе код, который будет работать в потоке синхронно. Если существует возможность такой ситуации, о которой пишешь ты, то такие случаи нужно учитывать отдельно (например использовать Qt::BlockingQueuedConnection), а лучше так никогда не делать. А прокрутка очереди сообщений, это вовсе не опасная практика. Она повсеместно используется в Qt: от оживления длительных операций и до модальных диалогов. Главное думать, что делаешь. Сообщение отредактировал BRE - 8.10.2009, 8:17 |
|
|
rnd |
8.10.2009, 8:54
Сообщение
#18
|
Студент Группа: Участник Сообщений: 54 Регистрация: 22.7.2009 Пользователь №: 930 Спасибо сказали: 1 раз(а) Репутация: 0 |
Надуманный?
Это крайне упрощенный пример. Мне сложно представить многопоточное приложение, использующие очереди, в котором несанкционированная прокачка сообщений не будет проблемой. На эти грабли наступали уже не раз. Приложение, над которым сейчас работаем активно использует пул потоков, пересылку сообщений между ними и минимум синхронизаций. Использование прокачки сообщений в коде - запрещено. Кстати модальные диалоги - тоже не айс, именно по этой причине. Я не говорю, что это должна быть запрещенная практика, просто многие люди не задумываются, что реально происходит при таком подходе. И каждое использование прокачки сообщений должно быть обдумано несколько раз, со всеми возможными последствиями. |
|
|
BRE |
8.10.2009, 9:12
Сообщение
#19
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
Мне сложно представить многопоточное приложение, использующие очереди, в котором несанкционированная прокачка сообщений не будет проблемой. На эти грабли наступали уже не раз. Приложение, над которым сейчас работаем активно использует пул потоков, пересылку сообщений между ними и минимум синхронизаций. Использование прокачки сообщений в коде - запрещено. Такие ситуации возникают тогда, когда нитка запущена и в пустую крутит цикл обработки сообщений, ожидая прихода внешнего события. После чего в своем контексте выполняет необходимый код. К тому же у вас в контексте этой нити можно выполнять разный код (в зависимости от слота). Вопрос: для чего эта нить висит и ждет этого события? Наверное лучше в нужный момент запустить нить, которая выполнит необходимое действие и завершиться. А если нужны сложности, конечно можно ограничивать себя по "самые помидоры" и держать активную нить, которая будут пытаться в своем контексте выполнять множество разных действия. Я не говорю, что это должна быть запрещенная практика, просто многие люди не задумываются, что реально происходит при таком подходе. И каждое использование прокачки сообщений должно быть обдумано несколько раз, со всеми возможными последствиями. +мульон |
|
|
Текстовая версия | Сейчас: 28.1.2025, 21:55 |