如何使发送和接收方法同时工作

How to make send and recv methods work simultaneously?

本文关键字:方法 工作 何使发      更新时间:2023-10-16

发送和 recv 方法工作正常,但当我发送退出时,recv 方法保持循环。我对多线程了解不多。当我发送"Q"时,连接应该正确关闭,并且必须侦听客户端。

如何同时为多个客户端提供服务?

int main()
{
    if (listen(sock, 5) == -1) {
        cerr<<"unable to listen for clients"<<endl;
        exit(1);
    }
    cout<<"TCPServer Waiting for client on port 8000"<<endl;
    sin_size = sizeof(struct sockaddr_in);
    connected = accept(sock, (struct sockaddr *)&client_addr,&sin_size);
    thread sds(snds),rvs(rcvs);
    if(sds.joinable()){
        sds.join();
    }
    if(rvs.joinable()){
        rvs.join();
    }
    close(sock);
    return 0;
}
void rcvs(){
    while(1){
        bytes_received = recv(connected,recv_data,1024,0);
        recv_data[bytes_received] = '';
        srz_rcv=recv_data;
        mb.ParseFromString(srz_rcv);
        srz_rcv=mb.msg();
        if (strcmp(srz_rcv.c_str() , "q") == 0 || strcmp(srz_rcv.c_str() , "Q") == 0){
            goto FINISH;
        }
        else{
            cout<<inet_ntoa(client_addr.sin_addr)<<" : "<<srz_rcv<<endl;
        }
        mb.Clear();
    }
    FINISH:
    close(connected);
    exit(0);
}
void snds(){
    while(1){
        cout<<"sent : ";
        cin>>send_data;
        mb.set_msg(send_data);
        mb.SerializeToString(&srz_snd);
        if (strcmp(srz_snd.c_str() , "q") == 0 || strcmp(srz_snd.c_str() , "Q") == 0){
            send(connected, srz_snd.c_str(),1024, 0);
            goto FINISH;
        }
        else{
            send(connected, srz_snd.c_str(),mb.ByteSize(), 0);
        }
        mb.Clear();
    }
    FINISH:
    close(connected);
    exit(0);
}

当您发送"Q"或"q"时,您似乎正在关闭接受的套接字。如果在同一进程中同时运行客户端和服务器时对此进行测试,则在执行close( socket )时可能不会返回阻塞recv。请参阅阻止 recv 在从另一个线程关闭套接字时不退出?那里的答案表明您可以在close之前致电shutdown。另一种选择是将recv更改为非阻塞并改为在select上阻塞,因为这可以让您更好地控制线程等待的条件。

另一方面,如果"Q"或"q"是由在不同进程中运行的客户端发送的,则只要字符串比较成功,您的代码"应该"就可以工作。但是,在处理 TCP 套接字时,始终建议优雅地关闭它们。请参阅正确关闭 TCP 套接字 在执行close之前,执行shutdown并处理套接字远程端的后续读取失败/fin。