Linux的I/O多路转接模型和select()
2011-09-05 15:43
302 查看
Linux的I/O多路转接模型:
在这种模型下,如果请求的I/O操作阻塞,它不是真正阻塞I/O,而是让其中一个函数等待,在这期间,I/O还能进行其他操作。select()和poll()就属于这种模型。
select()函数说明
对文件描述符操作的四个宏:
在这种模型下,如果请求的I/O操作阻塞,它不是真正阻塞I/O,而是让其中一个函数等待,在这期间,I/O还能进行其他操作。select()和poll()就属于这种模型。
select()函数说明
头文件 | #include<sys/types.h> #include<sys/time.h> #include<unistd.h> |
原型 | int select(int numfds,fd_set *readfds,fd_set *writefds,fd_set *exeptfds,struct timeval *timeout |
参数 | numfds:需要检查的号码最高的文件描述符+1 readfds:由select()监视的读文件描述符集合 writefds:由select()监视的写文件描述符集合 exeptfds:由select()监视的异常处理文件描述符集合 timeout: --- NULL:永远等待,直到捕捉到信号或文件描述符已经准备好为止 ---具体值:struct timeval的指针,若timeout时间还没准备好,则立即返回 ---0 :从不等待,测试所有指定的描述符并立即返回 |
返回值 | 成功:准备好的文件描述符 -1:出错 |
FD_ZERO(fd_set *set) | 清除一个文件描述符集合 |
FD_SET(int fd,fd_set *set) | 将一个文件描述符加入文件描述符集合 |
FD_CLR(int fd,fd_set *set) | 将一个文件描述符从集合中删除 |
FD_ISSET(int fd,fd_set *set) | 测试集合中一个给定位是否有变化 |
相关文章推荐
- Linux高性能服务器之多路转接(1)----select模型实现
- 【Linux网络编程】基于TCP协议 I/O多路转接(select) 的高性能回显服务器客户端模型
- Linux高性能服务器之多路转接(2)---poll模型
- Linux下的socket编程实践(七) I/O多路复用技术之select模型
- 【Linux】中I/O多路转接之select
- linux 多路转接之select
- Linux:I/O多路转接之select(有图有代码有真相!!!)
- Linux下高级I/O多路转接之select服务器
- 多路I/O转接之select模型
- Linux网络通信编程(套接字模型TCP\UDP与IO多路复用模型select\poll\epoll)
- 【Linux】I/O多路转接select
- 【Linux】多路 IO转接服务器 — select
- Linux下的socket编程实践(七) I/O多路复用技术之select模型
- 服务器与客户端的模型之select的多路转接
- Linux【网络编程】——I/O多路转接之Select服务器
- Linux网络通信编程(套接字模型TCP\UDP与IO多路复用模型select\poll\epoll)
- Linux网络编程【五】:TCP协议高性能服务器(http)模型之I/O多路转接select
- Linux I/O多路转接----poll模型
- linux下多路复用模型之Select模型
- 多路I/O转接之select模型