linux多线程网络编程详解(包含具体例子讲解)

本文介绍了如何在Linux环境中利用多线程实现并发服务器,详细解析了创建线程处理客户端请求的过程。给出了一个示例,服务器发送递增数字给客户端,客户端接收并加1回传,直至特定条件结束通信。代码中涉及关键函数如socket、bind、accept、pthread_create等,以及线程处理函数的实现。

    与多进程相同,采用多线程可以实现并发服务器,并且由于线程的系统开销小,切换时间短,对于需要处理大量客户的服务器而言其具有更大的优势,实现多线程并发服务器的基本流程是:当建立连接以后,服务器调用pthread_create()函数产生新的线程,由新的线程来处理客户端的请求,同时主线程等待另一个客户的连接请求,其中的典型的模板如下:

#include<sys/types.h>

#include<sys/socket.h>

#include<netinet/in.h>

#include<unistd.h>

#include<stdlib.h>

#include<pthread.h>

/***********function to be executed by the new thread**************/

void  *start_routine((void *)arg);



int main()

{

int listenf,connfd;

pthread_t tid;

type arg;

struct sockaddr_in servaddr,cliaddr;

/****************create the tcp sock *******************/

listenfd=socket(AF_INET,SOCK_STREAM,0);

bzero(&servaddr,sizeof(servaddr));
servaddr.sin_family=AF_INET;
servaddr.sin_addr.s_addr=htonl(INADDR_ANY);
servaddr.sin_port=htons(1032);

/******************************bind socket to address****************************/
bind(listenfd,(struct sockaddr *)&servaddr,sizeof(servaddr));
listen(listenfd,5);


while(1)

{

/********************accept the connection************

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值