day5:IO多路复用

这篇具有很好参考价值的文章主要介绍了day5:IO多路复用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

思维导图

day5:IO多路复用,网络编程,服务器,网络

TCP并发服务器的IO复用poll函数实现

#include <head.h>
#define SER_PORT 8888
#define SER_IP "192.168.232.133"
int main(int argc, const char *argv[])
{
	int sfd=socket(AF_INET,SOCK_STREAM,0);
	if(sfd==-1)
	{
		perror("sfd error:");
		return -1;
	}
	int reuse=1;
	if(setsockopt(sfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse))==-1)
	{
		perror("");
		return -1;
	}

	struct sockaddr_in sin;
	sin.sin_family=AF_INET;
	sin.sin_port=htons(SER_PORT);
	sin.sin_addr.s_addr=inet_addr(SER_IP);
	if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))==-1)
	{
		perror("bind error:");
		return -1;
	}

	if(listen(sfd,128)==-1)
	{
		perror("listen error:");
		return -1;
	}

	struct sockaddr_in cin;
	socklen_t socklen=sizeof(cin);
	int newfd=-1;
	int n=2;
	struct pollfd pfd[1024];
	pfd[0].fd=sfd;
	pfd[0].events=POLLIN;
	pfd[1].fd=0;
	pfd[1].events=POLLIN;
	
	struct sockaddr_in cin_arr[1024];
		

	while(1)
	{
		int res=poll(pfd,n,-1);
		if(res==-1)
		{
			perror("select error:");
			return -1;
		}
		else if(res==0)
		{
			printf("time out\n");
			return -1;
		}


			if(pfd[0].revents==POLLIN)
			{
				newfd=accept(sfd,(struct sockaddr*)&cin,&socklen);
				if(newfd==-1)
				{
					perror("newfd error:");
					return -1;
				}
				printf("[%s:%d:%d]发来链接请求\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),newfd);

				n++;
				pfd[n-1].fd=newfd;
				pfd[n-1].events=POLLIN;
				cin_arr[newfd]=cin;

			}

			if(pfd[1].revents==POLLIN)
			{
				char buf[128]="";
				scanf("%s",buf);
				for(int i=4;i<n+2;i++)
				{
					sendto(i,buf,sizeof(buf),0,(struct sockaddr*)&cin_arr[i],sizeof(cin_arr[i]));
				}
			}
		for(int i=2;i<n;i++)
		{
			if(pfd[i].revents==POLLIN)
			{
				char buf[128];
				bzero(buf,sizeof(buf));
				int rec=recv(pfd[i].fd,buf,sizeof(buf),0);
				if(rec==0)
				{
					close(pfd[i].fd);
					for(int j=i;j<n-1;j++)
					{
						pfd[j]=pfd[j+1];
					}
					n--;
					continue;
				}
				printf("[%s,%d]:%s\n",inet_ntoa(cin_arr[pfd[i].fd].sin_addr),ntohs(cin_arr[pfd[i].fd].sin_port),buf);
				strcat(buf,"111");
				send(pfd[i].fd,buf,sizeof(buf),0);
			}
		}
	}
	close(sfd);
	return 0;
}

TCP客户端IO复用select函数实现

#include <head.h>
#define SER_PORT 8888
#define SER_IP "192.168.232.133"
int main(int argc, const char *argv[])
{
	int sfd=socket(AF_INET,SOCK_STREAM,0);
	if(sfd==-1)
	{
		perror("");
		return -1;
	}

	struct sockaddr_in rin;
	rin.sin_family=AF_INET;
	rin.sin_port=htons(SER_PORT);
	rin.sin_addr.s_addr=inet_addr(SER_IP);
	
	if(connect(sfd,(struct sockaddr*)&rin,sizeof(rin))==-1)
	{
		perror("connect error");
		return -1;
	}
	
	fd_set readfds,tempfds;
	FD_ZERO(&readfds);
	FD_SET(0,&readfds);
	FD_SET(sfd,&readfds);
	int maxfd=sfd;
	
	while(1)
	{
		tempfds=readfds;
		int res=select(maxfd+1,&tempfds,NULL,NULL,NULL);
		if(res==-1)
		{
			perror("");
			return -1;
		}
		else if(res==0)
		{
			printf("manba out\n");
			return -1;
		}
		for(int i=0;i<=maxfd;i++)
		{
			if(!FD_ISSET(i,&tempfds))
			{
				continue;
			}
			if(i==0)
			{
				char buf[128];
				scanf("%s",buf);
				send(sfd,buf,sizeof(buf),0);
			}
			else if(i==sfd)
			{
				char buf[128]="";
				int res=recv(sfd,buf,sizeof(buf),0);
				printf("%d\n",res);
				printf("收到的消息为:%s\n",buf);
			}
		}

	}
	close(sfd);
	return 0;
}

day5:IO多路复用,网络编程,服务器,网络文章来源地址https://www.toymoban.com/news/detail-804215.html

到了这里,关于day5:IO多路复用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • BIO、NIO、IO多路复用模型详细介绍&Java NIO 网络编程

    上文介绍了网络编程的基础知识,并基于 Java 编写了 BIO 的网络编程。我们知道 BIO 模型是存在巨大问题的,比如 C10K 问题,其本质就是因其阻塞原因,导致如果想要承受更多的请求就必须有足够多的线程,但是足够多的线程会带来内存占用问题、CPU上下文切换带来的性能问题

    2024年02月14日
    浏览(48)
  • 网络编程day5

    思维导图 多路复用 selsect ser cli poll ser cli

    2024年01月22日
    浏览(42)
  • 23111 网络编程 day5

    2024年01月20日
    浏览(87)
  • 23062网络编程day5

    根据select TCP服务器流程图编写服务器 思维导图  

    2024年02月10日
    浏览(42)
  • 【APUE】网络socket编程温度采集智能存储与上报项目技术------多路复用

    作者简介: 一个平凡而乐于分享的小比特,中南民族大学通信工程专业研究生在读,研究方向无线联邦学习 擅长领域:驱动开发,嵌入式软件开发,BSP开发 作者主页:一个平凡而乐于分享的小比特的个人主页 文章收录专栏:网络socket编程之温度采集智能存储与上报项目,本

    2024年04月10日
    浏览(48)
  • 网络编程代码实例:IO复用版

    网络编程代码实例:IO复用版。 yezhening/Environment-and-network-programming-examples: 环境和网络编程实例 (github.com) Environment-and-network-programming-examples: 环境和网络编程实例 (gitee.com) 使用传输控制协议(TCP) 服务端多进程,一个服务端可连接多个客户端 用户在客户端终端输入,可多次

    2024年02月02日
    浏览(36)
  • 嵌入式学习-网络编程-Day5

    1.使用poll实现TCP服务器的并发 使用select实现TCP客户端的并发

    2024年01月20日
    浏览(62)
  • 计算机网络编程 | 多路I/O转接服务器

    欢迎关注博主 Mindtechnist 或加入【Linux C/C++/Python社区】一起学习和分享Linux、C、C++、Python、Matlab,机器人运动控制、多机器人协作,智能优化算法,滤波估计、多传感器信息融合,机器学习,人工智能等相关领域的知识和技术。 专栏:《网络编程》 多路IO转接服务器也叫做多

    2024年02月12日
    浏览(52)
  • Linux网络编程:多路I/O转接服务器(select poll epoll)

    文章目录: 一:select 1.基础API  select函数 思路分析 select优缺点 2.server.c 3.client.c 二:poll 1.基础API  poll函数  poll优缺点 read函数返回值 突破1024 文件描述符限制 2.server.c 3.client.c 三:epoll 1.基础API epoll_create创建   epoll_ctl操作  epoll_wait阻塞 epoll实现多路IO转接思路 epoll优缺点

    2024年02月11日
    浏览(53)
  • linux并发服务器 —— IO多路复用(八)

    半关闭只能实现数据单方向的传输;当TCP 接中A向 B 发送 FIN 请求关闭,另一端 B 回应ACK 之后 (A 端进入 FIN_WAIT_2 状态),并没有立即发送 FIN 给 A,A 方处于半连接状态 (半开关),此时 A 可以接收 B 发送的数据,但是 A 已经不能再向 B 发送数据 close不会影响到其他进程,shutdown会

    2024年02月09日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包