C++ Socket如何设置Accept和Recv的非阻塞 50

C++Socket如何设置Accept和Recv的非阻塞,也就是说有连接才接受,没链接继续往下走,同时在接受了之后,有消息就接收,没消息就继续下一步,求源码... C++ Socket如何设置Accept和Recv的非阻塞,也就是说有连接才接受,没链接继续往下走,同时在接受了之后,有消息就接收,没消息就继续下一步,求源码 展开
 我来答
春误双卿
2014-09-22 · TA获得超过725个赞
知道小有建树答主
回答量:580
采纳率:91%
帮助的人:459万
展开全部
void* CTCPClient::AUReceive(void *aInstance)
{
struct timeval tv_out;
CTCPClient *pInstance = (CTCPClient *)aInstance;
fd_set sockfd;
pInstance->m_IsExit = false;
char ReceiveDataInfo[1024]={0};

    char Temp[4] = {0};
   
while(pInstance->m_IsExit == false)
{
if(pInstance->m_socket == SOCKETERROR)
{
FD_ZERO(&sockfd);
}
else
{
FD_ZERO(&sockfd);
FD_SET(pInstance->m_socket,&sockfd);
}
fd_set mySet = sockfd;
memset(ReceiveDataInfo,0,1024);
int Max_ID = pInstance->m_socket;
int position=0;
tv_out.tv_sec = 0;
tv_out.tv_usec = 1000;
if(select(Max_ID+1,&mySet,NULL,NULL,&tv_out)>0) //主要这一句
{
long  nBytesRead = 0;

unsigned long nBytesToRecv = pInstance->mreceivebuflen -pInstance->hasrecvlen;
pInstance->recvsignal.Wait();
if(pInstance->m_socket == SOCKETERROR)
{
FD_ZERO(&sockfd);
pInstance->recvsignal.Release();
continue;
}
nBytesRead =  recv(pInstance->m_socket,(char *)pInstance->mreceivebuf + pInstance->hasrecvlen, nBytesToRecv, 0);
pInstance->recvsignal.Release();
if(nBytesRead == -1 || nBytesRead == 0)
{
pInstance->m_CSocket.SocketClose(pInstance->m_socket);
FD_ZERO(&sockfd);
pInstance->m_socket = SOCKETERROR;
continue;
}
pInstance->hasrecvlen += nBytesRead;
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"recv a package!");
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"recvlen is %ld",nBytesRead);
if((pInstance->FindCompletePackage(pInstance->receive,nBytesRead,pInstance->mreceivebuf))==false)
{
continue;
}
//printf("validlen is %d\n",pInstance->validlen);
pInstance->hasrecvlen =0;
if(pInstance->validlen < 8)
{
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"receive data is error(len is error)!");
continue;
}
for(int i =0 ; i< pInstance->validlen; i++)
{
sprintf(Temp,"%2x-", pInstance->receive[i]);
strcat(ReceiveDataInfo, Temp);
}
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"recv data is:%s",ReceiveDataInfo);
unsigned int recvSN = Char2Int(pInstance->receive);
position+=4;

unsigned int recvCMD = Char2Short(pInstance->receive + position);
position+=2;

unsigned long buflen = Char2Short(pInstance->receive + position);
position+=2;

if(pInstance->validlen - position != buflen)
{
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"receive data is error(len error)!");
continue;
}

stCommand newReceiveCommand;
newReceiveCommand.CmdSN = recvSN;
//newReceiveCommand.DataBuffer = "";


bool rest = pInstance->FindSentCommand(newReceiveCommand);
if(rest == false)
{
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"receive data is error(SN can not find)!");
continue;
}
if(newReceiveCommand.CmdCode != recvCMD)
{
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"receive data is error(CMD is error)!");
continue;
}

char *RecvData = new char[buflen];
memcpy(RecvData,pInstance->receive+position,buflen);
pInstance->UpdateSentCommand(recvSN,buflen,RecvData);

newReceiveCommand.WaitEvent->Release();
pInstance->m_CLog->ddprintf("CTCPClient","AUReceive",1,"send a signal of recv!");
delete[] RecvData;
}
else
Csleep(100);

}
//pInstance->m_ThdRecv.ThreadExit();
return NULL;
}

这个是recv设置非阻塞的方式,accept也是差不多

追问
编译不过
追答
。。。。我只是给你提供一个方式,这段代码当然编译不过,里面有太多的我自己的东西,很多自己定义的变量
浙江启扬智能科技有限公司
2023-06-12 广告
Android和ARM、Linux之间存在密切的联系。Android是一种基于Linux内核的嵌入式智能操作系统,它采用了ARM处理器作为其主要处理器架构。Android的内核和许多应用程序都是基于ARM架构编写的,包括处理器和内存管理器。... 点击进入详情页
本回答由浙江启扬智能科技有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式