多路复用I/O并发服务器

本文详细介绍了如何通过select函数实现I/O多路复用,以提高服务器并发处理能力。在不采用并发技术的情况下,服务器在处理一个请求时会忽略其他请求,导致客户端长时间等待。select函数允许在多个描述符中监听,当任一描述符就绪时,函数返回,从而避免了阻塞问题。通过FD_ZERO、FD_SET、FD_CLR和FD_ISSET等函数,可以管理描述符集合,监控读写和异常情况。该技术对于高效地处理大量并发连接至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

不采用并发技术,当服务器处理一个客户请求时,会拒绝其他客户端请求,造成其他客户要不断的请求并长期等待。
并发服务器有三种设计方式:
(1)多进程
(2)多线程
(3)多路复用I/O并发服务器
select 函数可以在多个扫描符中选择被激活的描述符。一个进程中有多个客户连接,即存在多个TCP 套接字描述符。select()函数阻塞
直到任何一个描述符被激活,即有数据传输。从而避免了进程为等待一个已连接上的数据而
无法处理其他连接。
说到底就是因为IO这样的太浪费时间了,所以需要在进行IO操作的时候将改socket堵塞

int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set * errorfds, struct timeval *timeout);

readfds: select() 函数监视的可读描述符集合。
writefds: select()函数监视的可写描述符集合。
errorfds: select()函数监视的异常描述符集合。
timeout: select()函数超时结束时间
返回值。如果成功返回总的位数,这些位对应已准备好的描述符。否则返回-1,并在errno
中设置相应的错误码。
FD_ZERO(fd_set *fdset):清空fdset 与所有描述符的联系
FD_SET(int fd, fd_set *fdset):建立描述符fd 与fdset 的联系
FD_CLR(int fd, fd_set *fdset):撤销描述符fd 与fdset 的联系
FD_ISSET(int fd,fd_set *fdset) ::检查与fdset 联系的描述符fd 是否可读写,返回非0表示可读写。
采用select()函数实现I/O 多路复用的基本步骤如下:
(1) 清空描述符集合
(2) 建立需要监视的描述符与描述符集合的联系
(3) 调用select()函数
(4) 检查所有需要监视的描述符,利用FD_ISSET 判断是否准备好
(5) 对已准备好的描述符进行I/O 操作

参考资料:
https://blog.csdn.net/rain_qingtian/article/details/11834513

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值