我是這樣弄的。int recv(SOCKET h_handle,char *pc_buff,int i_massagelen)//h_hanle發(fā)送方的套接字, i_massagelen是數(shù)據(jù)長度{int recvlen = 0while(recvlen<i_massagelen){recvlen += recv(h_handle,pc_buff+recvlen,i_massagelen-recvlen,0);}rerurn 0;}這個函數(shù)的作用是接收固定長度的數(shù)據(jù)。但是有個問題出現(xiàn)了,如果發(fā)送方在突然關(guān)閉了或者網(wǎng)絡(luò)原因斷網(wǎng)了。此函數(shù)就會永遠死等下去。請教怎么樣檢測h_handle是否關(guān)閉了?;蛘哒f怎么樣才能在h_handle關(guān)閉了此函數(shù)能馬上跳出while循環(huán)?(我表達能力有限)或者有什么函數(shù)能檢測h_handle是否處于連接狀態(tài)?
2 回答

慕工程0101907
TA貢獻1887條經(jīng)驗 獲得超5個贊
是你寫的有問題,socket的recv遇到錯誤返回的SOCKET_ERROR你也加到recvlen中去了,一直加,recvlen < i_messagelen永不成立,死循環(huán)。
int recv(SOCKET h_handle,char *pc_buff,
int i_massagelen)//h_hanle發(fā)送方的套接字, i_massagelen是數(shù)據(jù)長度
{
int recvlen = 0;
while(recvlen<i_massagelen)
{
int result = recv(h_handle,pc_buff+recvlen,i_massagelen-recvlen,0);
if (result <= 0) break;
recvlen+=result;
}
return recvlen;
}

炎炎設(shè)計
TA貢獻1808條經(jīng)驗 獲得超4個贊
因為服務(wù)器是一對多客戶端;
而對于客戶端來說,是1對1服務(wù)器;
所以,服務(wù)器在等待某個客戶端的時候,去執(zhí)行其他客戶端的請求。
- 2 回答
- 0 關(guān)注
- 290 瀏覽
添加回答
舉報
0/150
提交
取消