WinSock recv() timeout: setsockopt()-set value + half a second?

后端 未结 2 1537
说谎
说谎 2021-01-22 14:11

I am writing a cross-platform library which, among other things, provides a socket interface, and while running my unit-test suite, I noticed something strange with regard to ti

2条回答
  •  无人及你
    2021-01-22 14:29

    From Networking Programming for Microsoft Windows by Jones and Ohlund:

    SO_RCVTIMEO optval


    • Type: int
    • Get/Set: Both
    • Winsock Version: 1+
    • Description : Gets or sets the timeout value (in milliseconds) associated with receiving data on the socket

    The SO_RCVTIMEO option sets the receive timeout value on a blocking socket. The timeout value is an integer in milliseconds that indicates how long a Winsock receive function should block when attempting to receive data. If you need to use the SO_RCVTIMEO option and you use the WSASocket function to create the socket, you must specify WSA_FLAG_OVERLAPPED as part of WSASocket's dwFlags parameter. Subsequent calls to any Winsock receive function (such as recv, recvfrom, WSARecv, or WSARecvFrom) block only for the amount of time specified. If no data arrives within that time, the call fails with the error 10060 (WSAETIMEDOUT). If the receiver operation does time out the socket is in an indeterminate state and should not be used.

    For performance reasons, this option was disabled in Windows CE 2.1. If you attempt to set this option, it is silently ignored and no failure returns. Previous versions of Windows CE do implement this option.

    I'd think the crucial information in this is:

    If you need to use the SO_RCVTIMEO option and you use the WSASocket function to create the socket, you must specify WSA_FLAG_OVERLAPPED as part of WSASocket's dwFlags parameter

    I hope this is still useful :)

提交回复
热议问题