crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> [Qt 4.5.0] QHttp и QProgressDialog, странное поведение
SABROG
  опции профиля:
сообщение 17.6.2009, 11:17
Сообщение #1


Профессионал
*****

Группа: Участник
Сообщений: 1207
Регистрация: 8.12.2008
Из: Russia, Moscow
Пользователь №: 446

Спасибо сказали: 229 раз(а)




Репутация:   34  


Хочу отображать QProgressDialog сразу же как пользователь нажал на кнопку типа "Скачать". Если не делать dialog.exec(), то обычно диалог появляется через 4 секунды сам (minimumDuration) или при первом step'e (изменении значения в прогрессе). Вроде бы все работает нормально за исключением того, что пользователь ждет появления диалога секунд 10, а сам диалог появляется на секунды 3. Связано это с тем, что при запросе xml файла с http сервера присходит его генерирование на основе данных в БД, а сам процесс скачивания быстрый. Так вот если все-таки делать dialog.exec(), чтобы пользователь хотябы видел, что нажатие на кнопку запустило процесс ожидания файла с сервера, то получается следующая ситуация.

По сигналу void QHttp::dataReadProgress ( int done, int total ) [signal] я меняю прогресс на диалоге. Иногда всё нормально работает и при достижении done==total диалог автоматически закрывается (типа 100% скачано). А иногда done приходит меньше, чем total, но затем следует requestFinished не дойдя до 100% и диалог остается висеть на 98-99% пока не нажмешь cancel. Ввиду разного поведения в разных ситуациях я исключаю возможность того, что сервер передает неправильный размер данных.

Сообщение отредактировал SABROG - 17.6.2009, 12:34
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
SABROG
  опции профиля:
сообщение 20.6.2009, 11:20
Сообщение #2


Профессионал
*****

Группа: Участник
Сообщений: 1207
Регистрация: 8.12.2008
Из: Russia, Moscow
Пользователь №: 446

Спасибо сказали: 229 раз(а)




Репутация:   34  


Цитата(Kagami @ 20.6.2009, 11:43) *
и посмотреть, действительно ли это происходит.


Действительно происходит, но метод, который ты предложил об этом не сообщит, т.к. он вызывается только в методе 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   [Qt 4.5.0] QHttp и QProgressDialog   17.6.2009, 11:17
- - kwisp   SABROG, действительно странное поведение. так как...   17.6.2009, 11:26
- - SABROG   Решил вывести в консоль прогресс, вот что получил:...   17.6.2009, 12:03
- - kwisp   Цитата(SABROG @ 17.6.2009, 13:03) Похоже ...   17.6.2009, 13:00
- - SABROG   Прежде чем постить баг троллям попробуйте у себя т...   17.6.2009, 14:03
- - Litkevich Yuriy   QProgressDialog вообще чудной, У меня инициализир...   17.6.2009, 14:16
- - SABROG   Откуда берется понятно: void QProgressDialogPriva...   17.6.2009, 14:24
- - Litkevich Yuriy   Может оно и из-за английской (пиратская) Но у меня...   17.6.2009, 14:43
- - SABROG   Цитата(Litkevich Yuriy @ 17.6.2009, 15:43...   17.6.2009, 15:13
- - Litkevich Yuriy   Цитата(SABROG @ 17.6.2009, 19:13) я не на...   17.6.2009, 15:23
- - SABROG   Вот гифку накатал, которая показывает в чем пробле...   17.6.2009, 15:42
- - Litkevich Yuriy   поменял местами: progressDlg.setValue(done); progr...   17.6.2009, 16:40
- - SABROG   Цитата(Litkevich Yuriy @ 17.6.2009, 17:35...   17.6.2009, 16:47
- - Litkevich Yuriy   Сейчас код так выглядит: public slots: void b...   17.6.2009, 16:51
- - SABROG   Так ты же считерил //progressDlg.exec();...   17.6.2009, 16:56
- - Litkevich Yuriy   //progressDlg.exec(); progressDlg.setWin...   17.6.2009, 17:07
- - SABROG   Цитата(Litkevich Yuriy @ 17.6.2009, 18:07...   17.6.2009, 17:49
- - SABROG   Опаньки народ, получил такое письмо от троллей: Ц...   18.6.2009, 12:05
- - Litkevich Yuriy   где-то я уже слышал про рекомендацию использования...   18.6.2009, 15:33
|- - SABROG   Цитата(Litkevich Yuriy @ 18.6.2009, 16:33...   18.6.2009, 17:35
- - Litkevich Yuriy   с сеткой ещё не разу не работал, поэтому ничего пе...   18.6.2009, 17:55
- - SABROG   Вообще мне интересно влияет ли скорость скачивания...   18.6.2009, 17:59
- - Litkevich Yuriy   Цитата(SABROG @ 18.6.2009, 21:59) от коли...   18.6.2009, 18:04
|- - SABROG   Цитата(Litkevich Yuriy @ 18.6.2009, 19:04...   18.6.2009, 18:42
- - Авварон   бтв у меня программа выдавала double free при юзан...   18.6.2009, 22:12
- - SABROG   Цитата(SABROG @ 18.6.2009, 13:05) Передел...   19.6.2009, 18:00
|- - BRE   Цитата(SABROG @ 19.6.2009, 19:00) Я воспр...   19.6.2009, 21:10
- - Litkevich Yuriy   Цитата(BRE @ 20.6.2009, 1:10) Но если пом...   20.6.2009, 1:56
|- - BRE   Цитата(Litkevich Yuriy @ 20.6.2009, 2:56)...   20.6.2009, 5:53
|- - SABROG   В документации о сигналах и слотах написано: Цита...   20.6.2009, 8:30
- - Kagami   А меня, кстати, пару дней мучает вопрос: "Про...   20.6.2009, 10:32
|- - SABROG   Цитата(Kagami @ 20.6.2009, 11:32) А меня,...   20.6.2009, 10:35
- - Kagami   Попробуй переопределить Цитатаvoid QObject::discon...   20.6.2009, 10:43
- - SABROG   Цитата(Kagami @ 20.6.2009, 11:43) и посмо...   20.6.2009, 11:20
- - SABROG   Я в ступоре, сейчас тролли говорят, что это нормал...   22.6.2009, 18:23
- - SABROG   Баг признали, правда тикет еще не приняли. Пока со...   23.6.2009, 10:57
- - Litkevich Yuriy   а я что-то непонял насчёт этого варианта, разъясни   23.6.2009, 20:37
- - SABROG   Цитата(Litkevich Yuriy @ 23.6.2009, 21:37...   23.6.2009, 20:44
- - Litkevich Yuriy   я пока вижу только то, что добавился признак соеди...   23.6.2009, 20:50
|- - BRE   Цитата(Litkevich Yuriy @ 23.6.2009, 21:50...   24.6.2009, 8:09
- - Litkevich Yuriy   ну тогда вроде понятно, т.к. само событие finished...   24.6.2009, 8:24
|- - BRE   Цитата(Litkevich Yuriy @ 24.6.2009, 9:24)...   24.6.2009, 8:48
- - Litkevich Yuriy   тут у меня тоже мыслей нет.   24.6.2009, 9:02
- - SABROG   Говорят, что пофиксили: ЦитатаGood news, I think ...   25.6.2009, 16:55


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 28.1.2025, 20:32