FD_SET 打開類型fd_set的某一位
FD_ZERO初始化fd_set
FD_ISSET測試結(jié)構(gòu)fd_set中的描述字
直接到vc98/include的文件中查找他們就可以找到代碼。
select函數(shù):
系統(tǒng)提供select函數(shù)來實(shí)現(xiàn)多路復(fù)用輸入/輸出模型。原型:
#include <sys/time.h>
#include <unistd.h>
int select(int maxfd,fd_set *rdset,fd_set *wrset,fd_set *exset,struct timeval *timeout);
參數(shù)maxfd是需要監(jiān)視的最大的文件描述符值+1;rdset,wrset,exset分別對應(yīng)于需要檢測的可讀文件描述符的集合,可寫文件描述符的集合及異常文件描述符的集合。struct timeval結(jié)構(gòu)用于描述一段時間長度,如果在這個時間內(nèi),需要監(jiān)視的描述符沒有事件發(fā)生則函數(shù)返回,返回值為0。
FD_ZERO,FD_SET,FD_CLR,FD_ISSET: 參數(shù)maxfd是需要監(jiān)視的最大的文件描述符值+1;rdset,wrset,exset分別對應(yīng)于需要檢測的可讀文件描述符的集合,可寫文件描述符的集合及異常文件描述符的集合。struct timeval結(jié)構(gòu)用于描述一段時間長度,如果在這個時間內(nèi),需要監(jiān)視的描述符沒有事件發(fā)生則函數(shù)返回,返回值為0。
FD_ZERO,FD_SET,FD_CLR,FD_ISSET:
FD_ZERO(fd_set *fdset);將指定的文件描述符集清空,在對文件描述符集合進(jìn)行設(shè)置前,必須對其進(jìn)行初始化,如果不清空,由于在系統(tǒng)分配內(nèi)存空間后,通常并不作清空處理,所以結(jié)果是不可知的。
FD_SET(fd_set *fdset);用于在文件描述符集合中增加一個新的文件描述符。
FD_CLR(fd_set *fdset);用于在文件描述符集合中刪除一個文件描述符。
FD_ISSET(int fd,fd_set *fdset);用于測試指定的文件描述符是否在該集合中。
struct timeval結(jié)構(gòu):
struct timeval{
long tv_sec;//second
long tv_usec;//minisecond
}
timeout設(shè)置情況:
null:select將一直被阻塞,直到某個文件描述符上發(fā)生了事件。
0:僅檢測描述符集合的狀態(tài),然后立即返回,并不等待外部事件的發(fā)生。
特定的時間值:如果在指定的時間段里沒有事件發(fā)生,select將超時返回。
('fd_set') 是一組文件描述符(fd)的集合。由于fd_set類型的長度在不同平臺上不同,因此應(yīng)該用一組標(biāo)準(zhǔn)的宏定義來處理此類變量:
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個文件描述符,因?yàn)閒d_set其實(shí)只用了一個int的比特矢量來實(shí)現(xiàn),在大多數(shù)情況下,檢查 fd_set能包括任意值的文件描述符是系統(tǒng)的責(zé)任,但確定你的fd_set到底能放多少有時你應(yīng)該檢查/修改宏FD_SETSIZE的值。*這個值是系統(tǒng)相關(guān)的*,同時檢查你的系統(tǒng)中的select() 的man手冊。有一些系統(tǒng)對多于1024個文件描述符的支持有問題。
fd_set具體是怎樣實(shí)現(xiàn)的
這是把fd_set相關(guān)的源代碼匯總在一起。這樣應(yīng)該知道fd_set的實(shí)現(xiàn)詳細(xì)原理
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));
原文地址
http://mawnja.blog.163.com/blog/static/212061982008684928510/