QDatStream |
Здравствуйте, гость ( Вход | Регистрация )
QDatStream |
gpepsi |
17.9.2011, 21:22
Сообщение
#1
|
Студент Группа: Участник Сообщений: 73 Регистрация: 31.3.2010 Пользователь №: 1582 Спасибо сказали: 0 раз(а) Репутация: 0 |
Есть сокет. Попытался читать из него QDataStream.
На больших данных operator >> возвращает пустые данные. Есть предположение, что QDataStream читает пока читается, но если данные приходят кусками, то он не успевает все вычитывать. Есть ли что стандартное, для чтения потока? То есть читать пока читается либо пока не порвется соединение. |
|
|
BRE |
17.9.2011, 21:28
Сообщение
#2
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
|
|
|
gpepsi |
19.9.2011, 5:10
Сообщение
#3
|
Студент Группа: Участник Сообщений: 73 Регистрация: 31.3.2010 Пользователь №: 1582 Спасибо сказали: 0 раз(а) Репутация: 0 |
Ну так QDataStream так и читает. откуда тогда пустые данные Расскажи подробней что передается/принимается и как это выглядит в коде. просто строка длинной более MTU Сервер в методе incomingConnection
Клиент
З.Ы. Есть еще проблема. Когда сервер рвет соединение, то клиенту сразу приходит сигнал. А вот если клиент рвет, со серверу пофигу. Вот тестовый код
|
|
|
BRE |
19.9.2011, 7:37
Сообщение
#4
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
При серилизации QString вначале записывается ее длина, поэтому QDataStream может определить пришла она полностью или нет. Если она пришла не полностью, то ему не остается ничего другого, кроме возвращения пустой строки при чтении.
Можно пробовать читать из потока и если вернулась пустая строка, то ждать прихода следующего пакета и пробовать читать снова. Можно писать raw-строки без использования QDataStream и в качестве конца строки использовать "\r\n" (как это делается в http, ftp, ...). Тогда каждую порцию строку можно дописывать в буфер и контролировать маркер конца строки, если он получен, то вырезаем ее из буфера и обрабатываем. |
|
|
gpepsi |
19.9.2011, 7:51
Сообщение
#5
|
Студент Группа: Участник Сообщений: 73 Регистрация: 31.3.2010 Пользователь №: 1582 Спасибо сказали: 0 раз(а) Репутация: 0 |
Можно пробовать читать из потока и если вернулась пустая строка, то ждать прихода следующего пакета и пробовать читать снова. ну тогда нужно держать свой буфер накопления, а хотелось возложить это на QDataStream. Ему никак нельзя сказать, чтоб он читал покак не придет все ? Можно писать raw-строки без использования QDataStream и в качестве конца строки использовать "\r\n" (как это делается в http, ftp, ...). Тогда каждую порцию строку можно дописывать в буфер и контролировать маркер конца строки, если он получен, то вырезаем ее из буфера и обрабатываем. ну тоже самое - самому контролировать. Просто я думал, что для TCP это сделано (какой-нибудь QTcpStream) P.S. А что по поводу закрытия сокетов ? Сообщение отредактировал gpepsi - 19.9.2011, 8:34 |
|
|
BRE |
19.9.2011, 8:28
Сообщение
#6
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
ну тогда нужно держать свой буфер накопления, а хотелось возложить это на QDataStream. Ему никак нельзя сказать, чтоб он читал покак не придет все ? Не буду утверждать, а проверить времени сейчас нет, но скорее всего будет использоваться буфер сокета. Тебе нужно будет дождаться прихода всех пакетов для чтения строки, а пока это не так QDataStream будет возвращать пустую строку. ну тоже самое - самому контролировать. Просто я думал, что для TCP это сделано (какой-нибудь QTcpStream) А тут да - нужно будет заводить свой буфер. P.S. А что по поводу закрытия сокетов ? А с этим я не понял, что не приходит? Сигнал disconnected? Сообщение отредактировал BRE - 19.9.2011, 8:28 |
|
|
gpepsi |
19.9.2011, 8:34
Сообщение
#7
|
Студент Группа: Участник Сообщений: 73 Регистрация: 31.3.2010 Пользователь №: 1582 Спасибо сказали: 0 раз(а) Репутация: 0 |
А с этим я не понял, что не приходит? Сигнал disconnected? у клиента он проходит. Но сервер не подключен к сигналу, а просто проверяет isValid - вот он проболжает возвращать true после закрытия клиента. З.Ы. Может тогда унаследоваться от QDataStream и переопределить readRawData & writeRawData, чтоб остались все его возможности |
|
|
BRE |
19.9.2011, 9:52
Сообщение
#8
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
у клиента он проходит. Но сервер не подключен к сигналу, а просто проверяет isValid - вот он проболжает возвращать true после закрытия клиента. А ты состояние проверяй: SocketState QAbstractSocket::state () const З.Ы. Может тогда унаследоваться от QDataStream и переопределить readRawData & writeRawData, чтоб остались все его возможности А что это даст? Тебе нужен просто цикл добавить и ждать когда придут все данные для чтения хотя-бы одной строки. Можно в начале отправлять размер пакета и ждать пока придут все данные читая bytesAvailable, а только после этого вычитывать строку из потока. |
|
|
gpepsi |
19.9.2011, 10:01
Сообщение
#9
|
Студент Группа: Участник Сообщений: 73 Регистрация: 31.3.2010 Пользователь №: 1582 Спасибо сказали: 0 раз(а) Репутация: 0 |
|
|
|
Текстовая версия | Сейчас: 4.1.2025, 6:39 |