Używam gniazd C do implementacji niezawodnego protokołu UDP. Korzystam z następującego kodu, aby ustawić limit czasu na gnieździe, w którym czekam na potwierdzenie. Nie wiem, dlaczego dostaję errno 11, zasób jest tymczasowo niedostępny.Errno: 11, Zasoby tymczasowo niedostępne
//set timer for recv_socket
struct timeval tv;
tv.tv_usec = TIMEOUT_MS;
if(setsockopt(rcv_sock, SOL_SOCKET, SO_RCVTIMEO,&tv,sizeof(tv)) < 0){
printf("Error setting the socket timeout.\n");
}
int recv_msg_len;
if(recv_msg_len = recvfrom(rcv_sock, ackBuffer,sizeof(ackBuffer), 0,
(struct sockaddr *) &servAddr2, &fromSize) < 0){
//timeout reached
printf("Error Reporting: %d : %s\n", errno, strerror(errno));
num_timeouts++;
}
Próbowałem również wybranej metody, która została wymieniona w komentarzach. Mam następujący kod w pętli, ale recvfrom nigdy nie wychodzi.
fd_set set;
FD_ZERO(&set); /* empties the set */
FD_CLR(rcv_sock,&set); /* removes FD from the set */
FD_SET(rcv_sock,&set); /* adds FD to the set */
if(select(rcv_sock + 1, &set, NULL, NULL, &tv) < 0){
printf("\nError Reporting: %d : %s\n\n", errno, strerror(errno));
return -1;
}
if(!FD_ISSET(rcv_sock,&set)){ /* true if FD is in the set */
printf("socket is not set properly.\n");
}
Spróbuj użyć zamiast tego gniazd typu select() i nieblokujących. Metoda select() jest znacznie bardziej elastyczna, niezawodna i przenośna. –
Nie ma żadnego połączenia z 'recvfrom()' int on second snippet. – alk
'recvfrom()' zwraca 'ssize_t', a nie' int', BTW. – alk