Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.59/29: Рейтинг темы: голосов - 29, средняя оценка - 4.59
365 / 124 / 22
Регистрация: 08.01.2015
Сообщений: 1,418
Записей в блоге: 2

Почему функция recv() возвращает 0?

16.08.2018, 20:41. Показов 6616. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вроде бы, она возвращает либо -1, либо количество принятых байт.
Я отправляю сообщения от браузера на самодельный сервер, там сообщения принимаются функцией recv(). Так вот, в некоторых случаях она возвращает 0. При этом сокет принимается, т.к. accept равно целому положительному числу. Получается, что сокет принимается, но данные браузером не передаются?

В итоге, через какое-то время (несколько секунд) функция recv() перестает ждать данные и возвращает 0, хотя сокет сохраняется.

Добавлено через 2 минуты
Почему так происходит?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.08.2018, 20:41
Ответы с готовыми решениями:

Функция recv()
Хэлоу! Несколько вопросов по поводу использования функции recv() в Linux: 1) функция не успевает обработать все пришедшие пакеты и...

Почему виснет recv?
Не могу понять почему у меня в клиентской части программы виснет приём данных? Если выполнять всегда только 1у итерацию, то всё принимается...

Почему Winpcap не возвращает список интерфейсов?
Я беру первый и самый простой пример из официального учебника Winpcap, и он не показывает никакого девайса. Компиляция проходит...

10
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,575
16.08.2018, 20:42
Вот описание
RETURN VALUE
These calls return the number of bytes received, or -1 if an error
occurred. In the event of an error, errno is set to indicate the
error.

When a stream socket peer has performed an orderly shutdown, the
return value will be 0 (the traditional "end-of-file" return).

Datagram sockets in various domains (e.g., the UNIX and Internet
domains) permit zero-length datagrams. When such a datagram is
received, the return value is 0.

The value 0 may also be returned if the requested number of bytes to
receive from a stream socket was 0.
2
365 / 124 / 22
Регистрация: 08.01.2015
Сообщений: 1,418
Записей в блоге: 2
16.08.2018, 21:16  [ТС]
Цитата Сообщение от Someone007 Посмотреть сообщение
The value 0 may also be returned if the requested number of bytes to
receive from a stream socket was 0.
Похоже на это. А какое время эта функция ожидает получения байтов (если сокет - блокирующий)? Ссылку я посмотрел, но про время (таймаут) там идет речь лишь в случае неблокирующих сокетов.

Добавлено через 1 минуту
Или это время определяется браузером, в моем случае?

Добавлено через 2 минуты
Цитата Сообщение от Htext Посмотреть сообщение
if the requested number of bytes to
receive from a stream socket was 0
Хотя нет, не то: я запрашиваю 1024 байта.

Добавлено через 14 минут
Такое впечатление, что в некоторых ситуациях, при отправке запроса, браузер вначале создает сокет (а мой сервер его принимает при помощи accept() ). Однако, если нет данных для передачи серверу, то браузер... закрывает сокет через несколько секунд.
Правильно я ли понимаю, что именно это событие и вызывает срабатывание функции recv() на сервере, которая возвращает 0, так как ничего не было передано?
0
365 / 124 / 22
Регистрация: 08.01.2015
Сообщений: 1,418
Записей в блоге: 2
17.08.2018, 17:11  [ТС]
Вроде как, функция recv() ждет сколько-то секунд и если никаких данных не поступает, она возвращает значение 0 и программа выполняется дальше, как обычно.
Эх, вот кто бы пояснил, как можно изменить время ожидания (эти несколько секунд), сделав его равным, допустим, 1 минуте. Или оно на системном уровне прошито?
0
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
17.08.2018, 20:57
Цитата Сообщение от Htext Посмотреть сообщение
Вроде как, функция recv() ждет сколько-то секунд и если никаких данных не поступает, она возвращает значение 0 и программа выполняется дальше, как обычно
.
В случае, если задан таймаут и он истек, recv() возвращает -1.
Цитата Сообщение от Htext Посмотреть сообщение
кто бы пояснил, как можно изменить время ожидания
Вызовом setsockopt()

Строить догадки - занятие творческое, но проще и быстрее прочитать маны.
1
48 / 46 / 18
Регистрация: 27.04.2016
Сообщений: 169
17.08.2018, 21:58
Когда-то мне подобная вещь была нужна, здесь можно почитать про суть, а дальше копать маны.
0
Почетный модератор
 Аватар для Humanoid
11560 / 4354 / 453
Регистрация: 12.06.2008
Сообщений: 12,455
18.08.2018, 09:17
Когда от stream-сокета recv() возвращает 0, значит соединение закрылось. Вообще, 0 у read/recv обычно и означает, что что-то закончилось: достигнут конец файла, отключен tty-адаптер и т.п. Судя по описанию, которое добавил Someone007, только у датаграмм бывает нормальный 0.
2
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
18.08.2018, 10:09
Цитата Сообщение от Humanoid Посмотреть сообщение
Когда от stream-сокета recv() возвращает 0, значит соединение закрылось.
В большинстве случаев так, и логика нескольких извествных мне программ это предполагает.
Тем не менее ман предупреждает:
The value 0 may also be returned if the requested number of bytes to receive from a stream socket was 0.
И педанты пишут, что кроссплатформенный код не должен опираться на то, что 0 - закрытие сокета.
0
725 / 224 / 73
Регистрация: 01.03.2011
Сообщений: 643
18.08.2018, 10:29
Цитата Сообщение от gng Посмотреть сообщение
И педанты пишут, что кроссплатформенный код не должен опираться на то, что 0 - закрытие сокета.
имеется в виду, что пир сделал что-то типа shutdown(s, SHUT_WR) или что-то другое?
0
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
18.08.2018, 16:41
Лучший ответ Сообщение было отмечено Htext как решение

Решение

Цитата Сообщение от prik Посмотреть сообщение
имеется в виду, что пир сделал что-то типа shutdown(s, SHUT_WR) или что-то другое?
Где-то читал, что есть системы, где при чтении сокета ноль может вернуться при нормальной работе и нужно читать еще раз. Сам с таким не сталкивался, посткольку сетевые программы писал только под Посикс системы. А здесь все просто, если UDP - recv 0 означает пустую датаграмму, если TCP - закрытие соединения, либо сам пытался прочитать 0 байт.
1
365 / 124 / 22
Регистрация: 08.01.2015
Сообщений: 1,418
Записей в блоге: 2
18.08.2018, 18:27  [ТС]
Цитата Сообщение от gng Посмотреть сообщение
Вызовом setsockopt()
gng, спасибо! Я даже и не знал, до Вашего ответа, что у сокета можно устанавливать опции еще и этой функцией.

Не по теме:

Попутно выяснилось, как сделать, чтобы порт, по которому открыт сокет, не оставался занятым после закрытия программы: https://stackoverflow.com/ques... -reuseaddr , второй ответ. Там тоже используется setsockopt(). Тоже полезная вещь.

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.08.2018, 18:27
Помогаю со студенческими работами здесь

Псевдотерминал: функция возвращает ID дочернего процесса вместо 0 и 1
Товарищи, столкнулся с такой проблемой. Имеется вот код (нашел как пример вебрадио для распбери). Комментарии автора оставил. А теперь,...

Почему функция ничего не возвращает?
В общем пишу временный кастыль, который поможет преобразовать название страницы в нужный мне вид для определенных страниц. Функция -...

Почему функция возвращает undefined
Может кто подсказать, а то думалка уже болит. Наверняка ошибка очевидна, просто у меня не особо практики еще и не пойму в чем проблема.. ...

Почему функция не возвращает значение?
По заданию из учебника, нужно написать небольшую поисковую систему, используя все полученные знания. Вот написал такую программу, но...

Почему функция всегда возвращает 0?
bool trie_tree::consonants_check(char letter) { return tolower(letter) == ('w' || 'r' || 't' || 'p' || 's' || 'd' || 'f' || 'g' || 'h'...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru