最近学习了Windows sockets编程。对于FD_WRITE 事件的产生有了一些见解。
首先,在创建一个新的套接字时会产生一个FD_WRITE事件。另外FD_WRITE 事件只在发送缓冲区有多出的空位,而且可以容纳所要发送的数据时才能产生。发送缓冲区是系统内部提供的缓冲区。send() 函数先将数据写入到发送缓冲区中, 然后通过网络发送到接收端。
然后,下面三种情况也会触发FD_WRITE事件:
1、使用connect或WSAConnect函数,一个套接字首次建立了连接;
2、使用accept或WSAAccept函数,套接字被接受后;
3、若send,WSASend,sendto,WSASendto函数操作失败,返回WSAWOULDBLOCK错误,而且缓冲区变得可用。
最后,给出几个网络事件的意义:
Ø FD_READ 套接字接收到对方发送过来的数据包,表明这时可以去读套接字了
Ø FD_WRITE 数据缓冲区满后再次变空时,Winsock接口通过该通知码通知应用程序。表示可以继续发送数据了
(短时间内发送数据过多,便会造成数据缓冲区变满)
Ø FD_ACCEPT 监听中的套接字检测到有连接进入
Ø FD_CONNECT 如果用套接字去连接对方的主机,当连接动作完成以后会接收到这个通知码
Ø FD_CLOSE 检测到套接字对应的连接被关闭
2008-11-23 16:38:28