您的位置:首页 > 运维架构 > Linux

【Linux】中多路转接之poll

2017-07-12 11:14 429 查看
poll的简介:

poll是select服务器的一个优化,pollfd结构包含了要监视的event和发⽣的event,不再使用select“参数-值”传递的方式。

同时,pollfd并没有最大数量限制(但是数量过大后性能也是会下降)。 和select函数⼀样,poll返回后,需要轮询pollfd来获取就绪的描述符。

三个文件描述符:

epoll_creat:创建epoll模型,红黑树,就绪队列

epoll_ctl:管理epoll模型,管理红黑树,注册所需的就绪事件

epoll_wait:用来等待epoll模型,查找就绪队列

poll的 优点:

1,poll服务器,处理文件描述符的个数上面没有上限

2,poll将输入参数和输出参数进行了分离,没有必要在每一次的调用时进行设定

poll使用的是指针来实现:

1,poll是一个数组,作为输入输出函数 

2,fd作为返回值,该文件描述符上面发生了什么 

3,为0 非阻塞,大于0 的数字,等待多长时间,为-1 则永远进行等待 

代码的编写:

#include<stdio.h>
#include<poll.h>

int main()
{
struct pollfd fds;
fds.fd = 0;
fds.events = POLLIN;
fds.revents = 0;
int timeout = -1;
while(1)
{
stdin(poll(&fds,1,timeout));
case 0:
pritnf("timeout...");
break;
case -1:
pritnf("poll");
break;
default:
{
char buf=[1024];
if(fds.revents&POLLIN)
{
ssize_t s = read(fds,fd,buf,sizeof(buf));
if(s>0)
{

buf[s] = 0;
printf("echo %s\n",buf);

}

}
}
break;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Linux poll