zoukankan      html  css  js  c++  java
  • FD_SET,FD_ISSET,FD_ZERO,select

     

    FD_SET 打开类型fd_set的某一位
    FD_ZERO初始化fd_set
    FD_ISSET测试结构fd_set中的描述字
    直接到vc98/include的文件中查找他们就可以找到代码。

    select函数:
    系统提供select函数来实现多路复用输入/输出模型。原型:
    #include <sys/time.h>
    #include <unistd.h>  
         

    select函数:
    系统提供select函数来实现多路复用输入/输出模型。原型:
    #include <sys/time.h>
    #include <unistd.h>
    int select(int maxfd,fd_set *rdset,fd_set *wrset,fd_set *exset,struct timeval *timeout);
    参数maxfd是需要监视的最大的文件描述符值+1;rdset,wrset,exset分别对应于需要检测的可读文件描述符的集合,可写文件描述符的集合及异常文件描述符的集合。struct timeval结构用于描述一段时间长度,如果在这个时间内,需要监视的描述符没有事件发生则函数返回,返回值为0。
    FD_ZERO,FD_SET,FD_CLR,FD_ISSET:           参数maxfd是需要监视的最大的文件描述符值+1;rdset,wrset,exset分别对应于需要检测的可读文件描述符的集合,可写文件描述符的集合及异常文件描述符的集合。struct timeval结构用于描述一段时间长度,如果在这个时间内,需要监视的描述符没有事件发生则函数返回,返回值为0。
    FD_ZERO,FD_SET,FD_CLR,FD_ISSET:
    FD_ZERO(fd_set *fdset);将指定的文件描述符集清空,在对文件描述符集合进行设置前,必须对其进行初始化,如果不清空,由于在系统分配内存空间后,通常并不作清空处理,所以结果是不可知的。
    FD_SET(fd_set *fdset);用于在文件描述符集合中增加一个新的文件描述符。
    FD_CLR(fd_set *fdset);用于在文件描述符集合中删除一个文件描述符。
    FD_ISSET(int fd,fd_set *fdset);用于测试指定的文件描述符是否在该集合中。
    struct timeval结构:
    struct timeval{
    long tv_sec;//second
    long tv_usec;//minisecond
    }
    timeout设置情况:
    null:select将一直被阻塞,直到某个文件描述符上发生了事件。
    0:仅检测描述符集合的状态,然后立即返回,并不等待外部事件的发生。
    特定的时间值:如果在指定的时间段里没有事件发生,select将超时返回。

    ('fd_set') 是一组文件描述符(fd)的集合。由于fd_set类型的长度在不同平台上不同,因此应该用一组标准的宏定义来处理此类变量:

    fd_set set;   
    FD_ZERO(&set);       /* 将set清零 */    
    FD_SET(fd, &set);    /* 将fd加入set */   
    FD_CLR(fd, &set);    /* 将fd从set中清除 */    
    FD_ISSET(fd, &set);  /* 如果fd在set中则真 */

    在 过去,一个fd_set通常只能包含少于等于32个文件描述符,因为fd_set其实只用了一个int的比特矢量来实现,在大多数情况下,检查 fd_set能包括任意值的文件描述符是系统的责任,但确定你的fd_set到底能放多少有时你应该检查/修改宏FD_SETSIZE的值。*这个值是系 统相关的*,同时检查你的系统中的select() 的man手册。有一些系统对多于1024个文件描述符的支持有问题。

    fd_set具体是怎样实现的

    这是把fd_set相关的源代码汇总在一起。这样应该知道fd_set的实现详细原理

    define FD_SETSIZE      1024
    typedef unsigned long   fd_mask;

    #define NBBY    8               /* number of bits in a byte */
    #define NFDBITS (sizeof(fd_mask) * NBBY)        /* bits per mask */


    #define howmany(x, y)   (((x) + ((y) - 1)) / (y))

    typedef struct fd_set {
            fd_mask   fds_bits[howmany(FD_SETSIZE, NFDBITS)];
    } fd_set;

    #define _fdset_mask(n)   ((fd_mask)1 << ((n) % NFDBITS))
    #define FD_SET(n, p)     ((p)->fds_bits[(n)/NFDBITS] |= _fdset_mask(n))
    #define FD_CLR(n, p)     ((p)->fds_bits[(n)/NFDBITS] &= ~_fdset_mask(n))
    #define FD_ISSET(n, p)  ((p)->fds_bits[(n)/NFDBITS] & _fdset_mask(n))
    #define FD_COPY(f, t)    bcopy(f, t, sizeof(*(f)))
    #define FD_ZERO(p)      bzero(p, sizeof(*(p)))

    fd_set master_set_read;

    FD_SET(600,master_set_read);

    =>  master_set_read->fds_bits[(600)/32] |= (1<<(600%32)); 

  • 相关阅读:
    square(正方形)
    敌兵布阵
    Addition Chains(加法链)
    贪心算法理论
    难题,未解决
    Linux上vi(vim)编辑器使用教程
    linux下md5sum的使用
    Java读取csv文件
    S2JDBCタイプセーフAPI
    S2JDBCチュートリアル
  • 原文地址:https://www.cnblogs.com/wolflion/p/2539136.html
Copyright © 2011-2022 走看看