linux 多线程问题
大家好:
我在移植socket服务程序的时候遇见了这个问题,就是我创建了多个子线程。但是我把子线程退出就会出现主线程和所有子线程同时退出。我在我自己的电脑上面用ubuntu运行了没有这个问题。我移植到我的平台上面就出现这个问题了。这个是源代码
#include <stdio.h> // for printf
#include <stdlib.h> // for exit
#include <string.h> // for bzero
#include <fcntl.h>
#include <unistd.h>
#include <netinet/in.h> // for sockaddr_in
#include <sys/types.h> // for socket
#include <sys/socket.h> // for socket
#include <sys/stat.h>
#include <pthread.h>
#define SERVER_PORT 8090
#define LISTEN_QUEUE_LENGTH 20
#define BUFFER_SIZE 1024
#define MAX_THREAD_NUM 100
int thread_count = 0;
pthread_t threads[MAX_THREAD_NUM];
/**
*
* @param conn_socket
*/
void recv_data(int conn_socket);
/*
*
*/
int main(int argc, char** argv)
{
// œšÁ¢Socket
int server_socket = socket(PF_INET, SOCK_STREAM, 0);
if (server_socket < 0) {
printf("Socket create failed.\n");
return EXIT_FAILURE;
}
{
int opt = 1;
setsockopt(server_socket, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof (opt));
}
struct sockaddr_in server_addr;
bzero(&server_addr, sizeof (server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_addr.s_addr = htons(INADDR_ANY);
server_addr.sin_port = htons(SERVER_PORT);
if (bind(server_socket, (struct sockaddr*) &server_addr, sizeof (server_addr)))
{
printf("Bind port %d failed.\n", SERVER_PORT);
return EXIT_FAILURE;
}
if (listen(server_socket, LISTEN_QUEUE_LENGTH))
{
printf("Server Listen Failed!");
return EXIT_FAILURE;
}
bzero(&threads, sizeof(pthread_t) * MAX_THREAD_NUM);
while (1)
{
struct sockaddr_in client_addr;
socklen_t length = sizeof(client_addr);
printf("Server Recieve accept\n");
int client_conn = accept(server_socket, (struct sockaddr*) &client_addr, &length);
if (client_conn < 0)
{
printf("Server Accept Failed!\n");
return EXIT_FAILURE;
}
int pthread_err = pthread_create(threads + (thread_count++), NULL, (void *)recv_data, (void *)client_conn);
if (pthread_err != 0)
{
printf("Create thread Failed!\n");
return EXIT_FAILURE;
}
pthread_join(threads + thread_count,NULL);
}
close(server_socket);
return (EXIT_SUCCESS);
}
void recv_data(int conn_socket)
{
char buffer[BUFFER_SIZE];
bzero(buffer, BUFFER_SIZE);
int length = 0;
while (length = recv(conn_socket, buffer, BUFFER_SIZE, 0))
{
if (length < 0)
{
printf("Server Recieve Data Failed! code %d\n", length);
}
printf("Server Recieve Data%s\n", buffer);
bzero(buffer, BUFFER_SIZE);
}
close(conn_socket);
}