日期:2014-05-16  浏览次数:21121 次

recv 阻塞 怎么退出
一个客户端阻塞接收服务器端数据,服务器有两台(主,辅),如果主的断了,就连接辅的,如果主的启动,就去连接主的,就必须把辅的断掉;我发现,如果自己主动close(socket),如果客户端刚好在接收数据,则一直阻塞在recv,直到服务器发数据过来,才返回-1;
C/C++ code

void *RecvFromAPP(void *arg)
{
    char buf[2048+1]={0};
    char temp[2048+1]={0};
    int pos=0;
    int res=0;
    int len=0;
    while(1)
    {
        if(pos<len)
        {
            memset(temp,0,sizeof(temp));
            memcpy(temp,buf+pos,len-pos);
            memset(buf,0,sizeof(buf));
            memcpy(buf,temp,len-pos);
            pos=len-pos;
        }
        else
            pos=0;
        res=read_loop(app_arg.appsockfd,buf+pos,2048-pos);
        if(res==-1)
            break;
        else if(res==0)
        {
            Socket_Delete(app_arg.appsockfd);
            break;
        }
        else if(res>0)
        {
            len=pos+res;
            pos=Packet_DetachFromAPP(buf,len); //这个是分成完整的包,并放到队列中,会用来队列锁
        }
    }
    return NULL;
}


我本来想直接把这线程关掉,用phread_cancel,发现这个函数就算调用,线程也不一定会关;后来想用信号让他退出,但是发现他如果在分包,这时候队列的锁就没办法解,我想请问下大家:怎样退出这个了?

------解决方案--------------------
可以试一下shutdown(socket, SHUT_RD),让该套接字关闭读段。
------解决方案--------------------
你这样方法有点儿粗暴.

应该通过控制socket发送切断通知,让客户端自己挂断重新连接。