奇怪的多线程行为

时间:2017-07-03 08:25:34

标签: c multithreading sockets tcp pthreads

我正在编写一个程序,可以创建到给定IP地址的多个TCP连接。目前,所有程序所要做的就是连接。这是我第一次在C中做多线程的事情而且我遇到了一些我无法理解的行为。如果我在connection_handler函数的任意一行设置一个断点,那么无论num_clients是什么,它似乎只被调用一次。此外,好像connection_handler中的所有代码都没有被执行。

struct client_data {
    int id;
    in_addr_t ip;
    int port;
};

int main(int argc, char **argv)
{
    int num_clients,
        port;
    in_addr_t ip;

    num_clients = atoi(argv[1]);
    ip = inet_addr(argv[2]);
    port = atoi(argv[3]);

    struct client_data clients[num_clients];
    pthread_t threads[num_clients];

    for (int i = 0; i < num_clients; i++) {
        clients[i].id = id;
        client[i].ip = ip;
        client[i].port = port;
        setup_client_struct(i, ip, port, &clients[i]);
        pthread_create(&threads[i], NULL, connection_handler, (void *) &clients[i]);
    }

    return EXIT_SUCCESS;
}

void error(char *msg)
{
    fprintf(stderr, "%s\n", msg);
    exit(EXIT_FAILURE);
}

void * connection_handler(void *thread_arg)
{
    int sock_fd;
    struct client_data *data;
    struct sockaddr_in serv_addr;

    data = (struct client_data *) thread_arg;
    sock_fd = socket(AF_INET, SOCK_STREAM, 0);

    if (sock_fd < 0) error("Error creating socket");

    bzero((char *) &serv_addr, sizeof (serv_addr));
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_addr.s_addr = data->ip;
    serv_addr.sin_port = data->port;

    if (connect(sock_fd, (struct sockaddr *) &serv_addr, sizeof(serv_addr)) < 0) {
        error("Error connecting");
    }
    else {
        printf("Thread No. %d connected\n", data->id);
    }

    close(sock_fd);

    return 0;
}

1 个答案:

答案 0 :(得分:2)

main()函数的行for (int i = 0; i < num_clients; i++) { pthread_join(threads[i], NULL); } 之前添加以下代码:

{{1}}

上面的代码行将有助于等待主线程,直到所有其他创建的线程完成执行。