[Qt 4.5.0] QHttp и QProgressDialog, странное поведение |
Здравствуйте, гость ( Вход | Регистрация )
[Qt 4.5.0] QHttp и QProgressDialog, странное поведение |
Kagami |
20.6.2009, 10:32
Сообщение
#31
|
Старейший участник Группа: Участник Сообщений: 601 Регистрация: 2.2.2009 Пользователь №: 523 Спасибо сказали: 101 раз(а) Репутация: 9 |
А меня, кстати, пару дней мучает вопрос: "Происходит ли вызов disconnect() для всех сигналов и слотов объекта при его удалении?"
|
|
|
SABROG |
20.6.2009, 10:35
Сообщение
#32
|
Профессионал Группа: Участник Сообщений: 1207 Регистрация: 8.12.2008 Из: Russia, Moscow Пользователь №: 446 Спасибо сказали: 229 раз(а) Репутация: 34 |
А меня, кстати, пару дней мучает вопрос: "Происходит ли вызов disconnect() для всех сигналов и слотов объекта при его удалении?" Происходит. Цитата A signal-slot connection is removed when either of the objects involved are destroyed. Цитата Сигнал-слот соединения удаляются, когда любой из объектов разрушены.
|
|
|
Kagami |
20.6.2009, 10:43
Сообщение
#33
|
Старейший участник Группа: Участник Сообщений: 601 Регистрация: 2.2.2009 Пользователь №: 523 Спасибо сказали: 101 раз(а) Репутация: 9 |
Попробуй переопределить
Цитата void QObject::disconnectNotify ( const char * signal ) [virtual protected] и посмотреть, действительно это происходит |
|
|
SABROG |
20.6.2009, 11:20
Сообщение
#34
|
Профессионал Группа: Участник Сообщений: 1207 Регистрация: 8.12.2008 Из: Russia, Moscow Пользователь №: 446 Спасибо сказали: 229 раз(а) Репутация: 34 |
и посмотреть, действительно ли это происходит. Действительно происходит, но метод, который ты предложил об этом не сообщит, т.к. он вызывается только в методе QObject::disconnect(), а деструктор QObject::~OObject не использует метод disconnect(), он предпочитает сам пробежаться по списку и поудалять всё при этом никуда не сообщив. Скорее всего сомнение закралось в тот момент, когда представилась следующая картина. Один объект постоянно живет и его сигналы подключены к массе другим объектам, которые то появляются, то умирают. Узнает ли объект о том, что какие-то объекты уничтожились и нужно ли разрывать с ними связь. Так вот в деструкторе каждого QObject'a разрывается связь как с приемниками (receivers), так и с передатчиками (senders). В последнем случае удаляющийся объект как лазутчик получает доступ к объекту, который шлет ему сигналы и удаляет себя из его списка. Типа как в qip "Удалить себя из списка контакта". --- Сейчас еще одна проблема возникла, у QNetworkReply есть метод abort(), но это не слот и поэтому я никак не могу соединить кнопку cancel у QProgressDialog со слотом abort. Придется создавать свой собственный слот, т.к. наследоваться от QNetworkReply не хочется, да и бесполезно, ведь указатель на него генерит QNetworkAccessManager, а он ничего не знает о моем классе. --- Блин, тролли жгут. Когда я задал вопрос в тех поддержку о том кто должен удалять указатель на QNetworkReply возвращаемый от QNetworkAccessManager::get(), то получил ответ - читай документацию. Я прочитал и там было написано: Цитата Note: The slot is responsible for deleting the object at that poi Дословный перевод гугла: Цитата Примечание: слот отвечает за удаление объекта в этой точке. На самом деле не совсем понятно, что эта фраза означает. Толи объект удалится сам по себе при выходе из слота, толи пользователь должен его удалить. Сегодня фразу в документации поправили: Цитата After the request has finished, it is the responsibility of the user to delete the QNetworkReply object at an appropriate time. Цитата После запроса закончил, это ложится на пользователя, чтобы удалить QNetworkReply объекта в надлежащее время. Только теперь стало понятным, что указатель должен удалять сам пользователь. Будьте осторожны народ, а то memory leak схватите. Сообщение отредактировал SABROG - 20.6.2009, 17:29 |
|
|
SABROG |
22.6.2009, 18:23
Сообщение
#35
|
Профессионал Группа: Участник Сообщений: 1207 Регистрация: 8.12.2008 Из: Russia, Moscow Пользователь №: 446 Спасибо сказали: 229 раз(а) Репутация: 34 |
Я в ступоре, сейчас тролли говорят, что это нормальное поведение
Это что-же получается надо заводить какой-то флаг по пришествии finished() (ни у QNetworkReply, ни у QNetworkRequest нет методов типа state(), которые могли бы нам сообщить о состоянии сокетов или еще чего-то) и потом его проверять в остальных слотах, если вдруг finished() прийдет раньше чем сигналы типа error(), readyRead(), updateProgress(). Пойду смотреть примеры, что идут с исходниками и если увижу там, что какой-то конкретный сигнал там используется для определения завершения запроса тку их носом в этот код. Всё пипец им, нашел \examples\network\downloadmanager\:
Тут если пришел finished(), то QNetworkReply удаляется несмотря на то, что может прийти сигнал readyRead после этого. Стало быть файлик скачается битым. Сообщение отредактировал SABROG - 22.6.2009, 18:29 |
|
|
SABROG |
23.6.2009, 10:57
Сообщение
#36
|
Профессионал Группа: Участник Сообщений: 1207 Регистрация: 8.12.2008 Из: Russia, Moscow Пользователь №: 446 Спасибо сказали: 229 раз(а) Репутация: 34 |
Баг признали, правда тикет еще не приняли. Пока советуют такой вариант:
И действительно так работает. Еще одно подтверждение тому, что QEventLoop вклинивается в порядок вызовов слотов. Сказали, что будут разбираться после полудня, но я не знаю какой часовой пояс у этого человека. Хотя нет, знаю 09:37:42 Сообщение отредактировал SABROG - 23.6.2009, 11:01 |
|
|
Litkevich Yuriy |
23.6.2009, 20:37
Сообщение
#37
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
а я что-то непонял насчёт этого варианта, разъясни
|
|
|
SABROG |
23.6.2009, 20:44
Сообщение
#38
|
Профессионал Группа: Участник Сообщений: 1207 Регистрация: 8.12.2008 Из: Russia, Moscow Пользователь №: 446 Спасибо сказали: 229 раз(а) Репутация: 34 |
|
|
|
Litkevich Yuriy |
23.6.2009, 20:50
Сообщение
#39
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
я пока вижу только то, что добавился признак соединения через очередь. На первый взгляд это-то и должно приводить к косякам, а не наоборот.
|
|
|
BRE |
24.6.2009, 8:09
Сообщение
#40
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
я пока вижу только то, что добавился признак соединения через очередь. На первый взгляд это-то и должно приводить к косякам, а не наоборот. Бегло посмотрел исходники, по-моему, сигнал readyRead отсылается через очередь сообщений, а finished - директом. Поэтому, сначала приходит finished, а только после этого прокручивается цикл обработки сообщений и приходит последний readyRead. Хотя я пока не сообрасил, как с этим соотноситься "выпрямление" ситуации при изменении порядка выполнения connect. Сообщение отредактировал BRE - 24.6.2009, 8:11 |
|
|
Текстовая версия | Сейчас: 28.1.2025, 18:46 |