IO复用举例.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
IO复用举例

#include stdio.h#include stdlib.h#include string.h#include sys/types.h#include sys/socket.h#include netdb.h#include unistd.h#include fcntl.h#include sys/epoll.h#include errno.h#define MAXEVENTS 64#define SERVER_PORT 8000static int make_socket_non_blocking(int sfd){int flags, s;flags = fcntl(sfd, F_GETFL, 0);if (flags == -1){perror(fcntl);return -1;}flags |= O_NONBLOCK;s = fcntl(sfd, F_SETFL, flags);if (s == -1){perror(fcntl);return -1;}return 0;}static int create_and_bind(char *port){struct addrinfo hints;struct addrinfo *result, *rp;int s, sfd;memset(hints, 0, sizeof(struct addrinfo));hints.ai_family = AF_UNSPEC;/* Return IPv4 and IPv6 choices */hints.ai_socktype = SOCK_STREAM;/* We want a TCP socket */hints.ai_flags = AI_PASSIVE;/* All interfaces */s = getaddrinfo(NULL, port, hints, result);if (s != 0){fprintf(stderr, getaddrinfo: %s\n, gai_strerror(s));return -1;}for (rp = result; rp != NULL; rp = rp-ai_next){sfd = socket(rp-ai_family, rp-ai_socktype, rp-ai_protocol);if (sfd == -1)continue;s = bind(sfd, rp-ai_addr, rp-ai_addrlen);if (s == 0){/* We managed to bind successfully! */break;}close(sfd);}if (rp == NULL){fprintf(stderr, Could not bind\n);return -1;}freeaddrinfo(result);return sfd;}int main(int argc, char *argv[]){int sfd, s;int efd;struct epoll_event event;struct epoll_event *events;char *tport = SERVER_PORT;sfd = create_and_bind(tport);if (sfd == -1)abort();s = make_socket_non_blocking(sfd);if (s == -1)abort();s = listen(sfd, SOMAXCONN);if (s == -1){perror(listen);abort();}efd = epoll_create(1);if (efd == -1){perror(epoll_create);abort();}event.data.fd = sfd;event.events = EPOLLIN | EPOLLET;s = epoll_ctl(efd, EPOLL_CTL_ADD, sfd, event);if (s == -1){perror(epoll_ctl);abort();}/* Buffer where events are returned */events = calloc(MAXEVENTS, sizeof event);/* The event loop */while (1){int n, i;n = epoll_wait(efd, events, MAXEVENTS, -1);for (i = 0; i n; i++){if ((events[i].events EPOLLERR) || (events[i].events EPOLLHUP) || (!(events[i].events EPOLLIN)))

文档评论(0)

aena45 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档