《linux下c语言多线程,网络通信简单聊天程序》由会员分享,可在线阅读,更多相关《linux下c语言多线程,网络通信简单聊天程序(10页珍藏版)》请在技术文库上搜索。
1、LinuxLinux 下下 C C 语言多线程语言多线程, ,网络通信简单聊天程序网络通信简单聊天程序 Linux 下 C 语言多线程,网络通信简单聊天程序 功能描述:程序应用多线程技术,可是实现 1 对 N 进行网络通信聊 天。但至今没想出合适的退出机制,除了用 Ctr+C。出于演示目的, 这里采用 UNIX 域协议(文件系统套接字) ,程序分为客户端和服务 端。应用 select 函数来实现异步的读写操作。 先说一下服务端:首先先创建套接字,然后绑定,接下 进入一个无限循环,用 accept 函数,接受“连接”请求,然后调用 创建线程函数,创造新的线程,进入下一个循环。这样每当有一个 新的。
2、“连接”被接受都会创建一个新的线程,实现 1 对 N 的网络通 信。在服务端程序中线程中用一个 buffer 读写,为了避免错误,这 时就要给关键代码加上互斥锁 work_mutex,具体见代码。 服务端代码 1 #include 2 #include 3 #include 4 #include 5 #include 6 #include 7 #include 8 #include /这里没有用二进制信号量可以删掉 9 10 char buffer1024; /读写用的区域 11 sem_t bin_sem; /没用到的二进制信号量,可以删掉 12 void *pthread_function。
3、(void *arg); /线程入口函数声明 13 pthread_mutex_t work_mutex; /声明互斥锁 14 15 int main() 16 int result; /整数变量用来储存调用函数的返回值 17 struct sockaddr_un server_address, client_address; /UNIX 域的套接字,server_address 用于服务端的监听, client_address 用于客户端连接后的套接字 18 int client_len; /连接后,accept 函数会把客户端的地 址的长度储存在这 19 int server_socket。
4、fd, client_socketfd;/服务端和客户 端的套接字文件描述符 20 pthread_t a_thread; /线程 ID 标志 21 pthread_attr_t thread_attr; /线程的属性,后面可以看 的,被我注释掉了,没用到,可以删掉。 22 23 result = sem_init( /初始化二进制信 号量,因为用了互斥锁,所以没用到,可以删掉 24 if(result != 0) 25 perror(“sem_init“); 26 exit(EXIT_FAILURE); 27 28 29 result = pthread_mutex_init(/初 始化互斥。
5、锁 30 if(result != 0) 31 perror(“pthread_mutex_init“); 32 exit(EXIT_FAILURE); 33 34 35 server_socketfd = socket(AF_UNIX, SOCK_STREAM, 0);/ 创建套接字,用 TCP 连接方式,出于演示目的只用 UNIX 域套接字。 36 37 server_address.sun_family = AF_UNIX; 38 strcpy(server_address.sun_path, “server_socket“); 39 40 unlink(“server_socket“)。
6、; /在绑定之前,把以前存在当 前目录下的套接字删除 41 42 result = bind(server_socketfd, (struct sockaddr*) /绑定 43 if(result != 0) 44 perror(“bind“); 45 exit(EXIT_FAILURE); 46 47 48 result = listen(server_socketfd, 5);/监听,最多允许 5 个连接请求 49 if(result != 0) 50 perror(“listen“); 51 exit(EXIT_FAILURE); 52 53 54 client_len = sizeo。
7、f(client_address); 55 while(1) /开始进入无限循环 56 /* printf(“If you want to quit, please enter quitn“); 57 printf(“Do you want to accept a connectiongn“); 58 memset(buffer, 0, sizeof(buffer); 59 fgets(buffer, sizeof(buffer), stdin); 60 if(strncmp(“quit“, buffer, 4)=0) break; */ 61 62 client_socketfd = acc。
8、ept(server_socketfd, (struct sockaddr*) /接受一个 连接请求 63 64 /* result = pthread_attr_init( 65 if(result != 0) 66 perror(“pthread_attr_init“); 67 exit(EXIT_FAILURE); 68 69 result = pthread_attr_setdetachstate( 70 if(result != 0) 71 perror(“pthread_attr_setdetachstate“); 72 exit(EXIT_FAILURE); 73 */ 74 r。
9、esult = pthread_create( /成功接受一个 请求后,就会创建一个线程,然后主线程又进入 accept 函数,如果 此时没有连接请求,那么主线程会阻塞 75 if(result != 0) 76 perror(“pthread_create“); 77 exit(EXIT_FAILURE); 78 79 80 81 82 83 void *pthread_function(void *arg) /线程入口函数,每调 用一次 pthread_create,都会创建一个新的线程 84 int fd = (int) arg; /把函数参数,即连接成功后的套接 字,赋给 fd. 85。
10、 int result; 86 fd_set read_fds; /文件描述符集合,用于 select 函数 87 int max_fds; /文件描述符集合的最大数 88 89 printf(“%d id has connected!n“, fd); 90 while (1) 91 92 FD_ZERO(/清空集合 93 FD_SET(0, /将标准输入放入监听的文件 描述符集合, 这个用于读取标准输入,即键盘的输入 94 FD_SET(fd, /将连接后的客户文件描述符 放入监听的文件描述符集合, 这个用于向客户端读取数据 95 max_fds = fd + 1; 96 97 / sem_。
11、wait( 98 pthread_mutex_lock( /对关键区域上 锁 99 printf(“%d has get the lockn“, fd); 100 result = select(max_fds, /开始监听 那些文件描述符出于可读状态 101 if(result 2 #include 3 #include 4 #include 5 #include 6 #include 7 #include 8 9 int main() 10 int result; 11 int socketfd; 12 int len; 13 struct sockaddr_un address; 14 。
12、fd_set read_fds, test_fds; 15 int fd; 16 int max_fds; 17 char buffer1024; 18 19 socketfd = socket(AF_UNIX, SOCK_STREAM, 0); 20 21 address.sun_family = AF_UNIX; 22 strcpy(address.sun_path, “server_socket“); 23 len = sizeof(address); 24 25 result = connect(socketfd, (struct sockaddr*) 26 if(result = -。
13、1) 27 perror(“connect“); 28 exit(EXIT_FAILURE); 29 30 31 FD_ZERO( 32 FD_SET(0, 33 FD_SET(socketfd, 34 max_fds = socketfd +1; 35 36 printf(“Chat now!n“); 37 38 while(1) 39 test_fds = read_fds; 40 result = select(max_fds, 41 if(result 1) 42 perror(“select“); 43 exit(EXIT_FAILURE); 44 45 46 if(FD_ISSET。
14、(0, 48 / printf(“send:“); 49 fgets(buffer, sizeof(buffer), stdin); 50 if(strncmp(“quit“, buffer, 4)= 0) 51 printf(“nYou are going to quitn“); 52 break; 53 54 result = write(socketfd, buffer, sizeof(buffer); 55 if(result = -1) 56 perror(“write“); 57 exit(EXIT_FAILURE); 58 59 60 if(FD_ISSET(socketfd, 62 result = read(socketfd, buffer, sizeof(buffer); 63 if(result = -1) 64 perror(“read“); 65 exit(EXIT_FAILURE); 66 else if(result = 0) 67 printf(“The other side has termianl chat!n“); 68 break; 69 else 70 printf(“recieve: %s“, buffer); 71 72 73 74 close(socketfd); 75 exit(EXIT_SUCCESS); 76 77 。