免费注册 查看新帖 |

Chinaunix

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

关于FD_SET的内存越界问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-10-15 10:10 |只看该作者 |倒序浏览
问题:在TCP的接收队列超过一定数量后(1024左右),经常会发生内存异常。
分析:
select支持的fdset有限,在当前内核版本下,fdset是128长度的unsigned long数组,只支持1024个文件描述符,当大于1024就无法支持,但不至于导致内存问题。
FD_SET在i386的实现是基于汇编bstl,fd足够大时,可以设置超越fdset长度的内存位置。
测试程序如下
#include <stdlib.h>
struct tags
{
        int a;
        fd_set fds;
        int b;
};
int main()
{
        struct tags tag;
        tag.a = 0;
        tag.b = 0;
        printf("fds:%d, tags:%d\n", sizeof(fd_set), sizeof(tag));
        FD_ZERO(&tag.fds);
        FD_SET(1, &tag.fds);
        FD_SET(sizeof(fd_set) * 8 + 1, &tag.fds);
        printf("a:%d, b:%d, fds:%d\n", tag.a, tag.b, tag.fds);
}
输出结果
fds:128, tags:136
a:0, b:2, fds:2
如以上结果,b发生了越界。
set_bit应该也存在同样的问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP