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

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

16.08.2018, 20:41. Показов 6525. Ответов 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,574
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
11557 / 4352 / 452
Регистрация: 12.06.2008
Сообщений: 12,454
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
Ответ Создать тему
Новые блоги и статьи
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru