免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3150 | 回复: 3
打印 上一主题 下一主题

[C] epoll 能否监听某一区间fd [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-01-13 12:14 |显示全部楼层 |倒序浏览
大家好,我使用epoll 监听网络请求
但是会把标准输出输入 ,即 0 1描述符也做监听
我不想让 0, 1 描述符 用做网络通信怎么处理呢,
谢谢

论坛徽章:
0
2 [报告]
发表于 2014-01-13 16:07 |显示全部楼层
我看代码,没有加入0 1 描述符,不知道是怎么会监听到的,epoll 监听必须加入,不是指定一个最大的maxfd,0~maxfd 的都会被监听?
类似select,有没有可能是默认添加的,不是显示的代码加进去的?回复 2# yulihua49


   

论坛徽章:
0
3 [报告]
发表于 2014-01-13 16:48 |显示全部楼层
不会,仔细看了代码,确实没有添加 0 1 描述符,
我把执行日志打印出来,发现也是,
先从epoll_wait返回的 0 描述符,
之后才有(epoll_ctl (epfd, EPOLL_CTL_ADD, fd, &ev)
语句加入 0 描述符回复 4# yulihua49


   

论坛徽章:
0
4 [报告]
发表于 2014-01-14 11:08 |显示全部楼层
找到原因了,因为在64位机器上,使用的的struct epoll_event 结构体是自定义的,
           struct epoll_event_my {
               unsigned long events;      /* Epoll events */
               epoll_data_t data;      /* User data variable */
           };           

标准的结构体如下:
struct epoll_event {
               __uint32_t events;      /* Epoll events */
               epoll_data_t data;      /* User data variable */
           };

unsigned long 64位机器是 8字节
__uint32_t  是4字节
故出现莫名其妙的问题
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP