使用 Select 的套接字客户端 [英] Socket client using Select

查看:42
本文介绍了使用 Select 的套接字客户端的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试实现一个客户端函数,该函数可以使用 select() 函数与多个服务器建立连接.但我不是使用 select() 函数的专家.但是,我的客户端可以启用与多个服务器的连接,但无法从这些多个服务器读取消息.

Im trying to implement a client function which can establish connection with multiple servers using select() function. But I'm not a expert in using select() function. However my client can enable a connection with the multiple servers but it could not able to read messages from those multiple servers.

根据我的以下示例,我将客户端与两台服务器连接起来 (192.168.100.136, 192.168.100.138).连接这两个服务器后,我的客户端只从一台服务器接收消息 (192.168.100.136),而不是从多个服务器接收消息..

As per my following example , i connected my client with two servers ( 192.168.100.136, 192.168.100.138). After connected with those two servers , my client was receiving messages from only one server (192.168.100.136) , instead of receiving messages from multiple servers..

我不确定我在示例程序中使用 select() 函数的方式.请更正我的示例应用程序以获得所需的 o/p..提前致谢

I'm not sure about the way I used select() function in my sample program. Please correct my sample application to get the desired o/p.. Thanks in advance

int main()
{
    int port = 10001 ;
    char ip[][32] = {"192.168.100.136","192.168.100.138"};
    int count = 2 ;
    int ret = clientSelect(ip,port,count);
    return 0 ;
}   
int clientSelect(char **ipAddr ,int port , int count)
    {
    SOCKET max_sd = 0;
    SOCKET socketId[10] = {0};
    SOCKET sd = 0 ;
    SOCKET client_sock[1024] = {0} ;
    fd_set readfds;
    int i ,j , ret;
    char recvBuf[1024] = "";
    char errMsg[256] = "" ;
    struct sockaddr_in server ;

    FD_ZERO(&readfds);
    // Socket Initialization
    for(i = 0; i<count ; i++)
    {
        ret = initSocket(&socketId[i]);//Small function to create socket
        if (ret != 1)
        {
            return ret ;
        }
        //Server info
        server.sin_addr.s_addr  = inet_addr(ipAddr[i]);
        server.sin_family       = AF_INET;
        server.sin_port         = htons(port);
        // Conect to server
        if (connect(socketId[i], (struct sockaddr *)&server , sizeof(server)) < 0)
        {
            printf("connect ::Failed to connect to server %s:%d",ipAddr[i],port);
            return -1;
        }
        // Set Socket fd
        FD_SET(socketId[i], &readfds); 

        max_sd = (max_sd>socketId[i])?max_sd:socketId[i];
    }
    while(TRUE)
    {
        ret = select(max_sd + 1, &readfds, NULL, NULL, NULL);
        if (ret < 0)
        {
            printf("select failed\n ");
            return -1;
        }
        for ( j = 0 ; j<max_sd ; j++)
        {
            sd = client_sock[j] ;
            if (FD_ISSET(sd, &readfds)) 
            {
                ret = recv(sd,(char *)recvBuf,sizeof(recvBuf), 0);
                if(ret > 0 )
                {
                    printf("Message received from socket %d : %s\n",sd,recvBuf);
                    send(sd,(char *)recvBuf,strlen(recvBuf),0);
                }
            }
        }
    }

    return ret ;

}

推荐答案

fd_set 必须在每次使用前初始化.

The fd_set must be initialized before each use.

你的代码应该是这样的:

Your code should be like:

int clientSelect(char **ipAddr ,int port , int count)
{
    SOCKET max_sd = 0;
    SOCKET socketId[10] = {0};
    SOCKET sd = 0 ;

    fd_set readfds;
    int i ,j , ret;
    char recvBuf[1024] = "";
    char errMsg[256] = "" ;
    struct sockaddr_in server ;

    // Socket Initialization
    for(i = 0; i<count ; i++)
    {
        ret = initSocket(&socketId[i]);//Small function to create socket
        if (ret != 1)
        {
            return ret ;
        }
        //Server info
        server.sin_addr.s_addr  = inet_addr(ipAddr[i]);
        server.sin_family       = AF_INET;
        server.sin_port         = htons(port);
        // Conect to server
        if (connect(socketId[i], (struct sockaddr *)&server , sizeof(server)) < 0)
        {
            printf("connect ::Failed to connect to server %s:%d",ipAddr[i],port);
            return -1;
        }       
    }


    while(TRUE)
    {
        // init fd_set
        FD_ZERO(&readfds); // added by siva to initialize socket descriptors
        for(i = 0; i<count ; i++)
        {
            //FD_ZERO(&readfds); // Commented by siva to avoid initialization for each socket
            FD_SET(socketId[i], &readfds); 
            max_sd = (max_sd>socketId[i])?max_sd:socketId[i];
        }
        ret = select(max_sd + 1, &readfds, NULL, NULL, NULL);
        if (ret < 0)
        {
            printf("select failed\n ");
            return -1;
        }
        // warning: you don't know the max_sd value
        for(i = 0; i<count ; i++)
        {
            sd = socketId[i] ;
            if (FD_ISSET(sd, &readfds)) 
            {
                ret = recv(sd,(char *)recvBuf,sizeof(recvBuf), 0);
                if(ret > 0 )
                {
                    printf("Message received from socket %d : %s\n",sd,recvBuf);
                    send(sd,(char *)recvBuf,strlen(recvBuf),0);
                }
            }
        }
    }

    return ret ;

}

这篇关于使用 Select 的套接字客户端的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆