Güvenilir bir UDP protokolü uygulamak için c soketleri kullanıyorum. Bir onay için beklediğim bir yuvada zaman aşımı ayarlamak için aşağıdaki kodu kullanıyorum. Neden errno 11 aldığımı bilmiyorum, kaynak geçici olarak kullanılamıyor.Errno: 11, Kaynak Geçici Olarak Kullanılamıyor
//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++;
}
Ayrıca yorumlarda belirtilen seçme yöntemini denedim. Bir döngü içinde aşağıdaki kodlarım var, ama geri çekilme asla zaman aşımına uğruyor.
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");
}
Bunun yerine select() ve bloke olmayan soketleri kullanmayı deneyin. Select() yaklaşımı çok daha esnek, güvenilir ve taşınabilirdir. –
Recvfrom() 'int ikinci snippet'e çağrı yok. – alk
'recvfrom()' 'ssize_t'' int', BTW'yi döndürür. – alk