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

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

16.08.2018, 20:41. Показов 6486. Ответов 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,569
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
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
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
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru