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