两个CAsyncSocket的小问题

时间:2022-02-25 13:59:44

在CAsyncSocket里Connect后总返回0,经查发现如下信息
 The socket is marked as nonblocking and the connection 
cannot be completed immediately
这个错误还覆盖了其他的错误
应该怎么解决(判断出错)


如何知道GetLastError返回的整数究竟对应哪个错误

谢谢

6 个解决方案

#1



2:

Declare Function FormatMessage Lib "kernel32" Alias "FormatMessageA" _
    (ByVal dwFlags As Long, lpSource As Any, ByVal dwMessageId As Long, ByVal dwLanguageId As Long, _
    ByVal lpBuffer As String, ByVal nSize As Long, Arguments As Long) As Long
  
Public Const FORMAT_MESSAGE_ALLOCATE_BUFFER = &H100
Public Const FORMAT_MESSAGE_ARGUMENT_ARRAY = &H2000
Public Const FORMAT_MESSAGE_FROM_HMODULE = &H800
Public Const FORMAT_MESSAGE_FROM_STRING = &H400
Public Const FORMAT_MESSAGE_FROM_SYSTEM = &H1000
Public Const FORMAT_MESSAGE_IGNORE_INSERTS = &H200
Public Const FORMAT_MESSAGE_MAX_WIDTH_MASK = &HFF
Public Const LANG_USER_DEFAULT = &H400&


Public Function GetSystemError(ByVal Number As Long) As String
    
  Dim sMsgBuf As String * 257, dwLen As Long
  
  dwLen = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM _
    Or FORMAT_MESSAGE_IGNORE_INSERTS Or FORMAT_MESSAGE_MAX_WIDTH_MASK, ByVal 0&, _
    Number, LANG_USER_DEFAULT, ByVal sMsgBuf, 256&, 0&)
  
  If dwLen > 0 Then GetLastErrorStr = LeftB$(sMsgBuf, dwLen)
End Function

#2


谢谢,第二个问题已经解决了,那么第一个问题呢?

#3


这个问题一般是服务器端机器还没有开启,你应该在OnConnect()函数中判断是否连接成功。至于错误,可以用GetLastError()得到,然后,在VC中有一个Error Lookup的工具,可以用来查找该错误号对应于什么错误。

#4


实际上我的连接是成功的,就是说,虽然Connect返回值是0,连接仍然建立了

如果能运行到onconnect那就肯定连接成功了啊,所以我在Connect里判断是否
连接成功

我不知道说清楚了没有

#5


这个问题与socket descriptor的属性阻塞非阻塞有关。

connect操作是阻塞的。调用connect之前先确定一个timeout时间t、设置一个事件变量event、并以event为参数select套接字 FD_CONNECT事件,返回错误之后,获得错误码,如果是不10035—WOULDBLOCK则连接失败。如果是,等待event事件时间t,如果等到,调用WSAEnumNetworkEvents 获得一个LPWSANETWORKEVENTS的指针,通过它的成员iErrorCode
获得connect的错误信息。具体如下:LPWSANETWORKEVENTS->iErrorCode[fd_connect];
如果它为零,则连接成功,如果不为零,则失败,且它就是错误代码。
注意:如果等待函数超时,则需要清除connect操作。时间t的设置与具体情况有关。

#6


36187关注!

#1



2:

Declare Function FormatMessage Lib "kernel32" Alias "FormatMessageA" _
    (ByVal dwFlags As Long, lpSource As Any, ByVal dwMessageId As Long, ByVal dwLanguageId As Long, _
    ByVal lpBuffer As String, ByVal nSize As Long, Arguments As Long) As Long
  
Public Const FORMAT_MESSAGE_ALLOCATE_BUFFER = &H100
Public Const FORMAT_MESSAGE_ARGUMENT_ARRAY = &H2000
Public Const FORMAT_MESSAGE_FROM_HMODULE = &H800
Public Const FORMAT_MESSAGE_FROM_STRING = &H400
Public Const FORMAT_MESSAGE_FROM_SYSTEM = &H1000
Public Const FORMAT_MESSAGE_IGNORE_INSERTS = &H200
Public Const FORMAT_MESSAGE_MAX_WIDTH_MASK = &HFF
Public Const LANG_USER_DEFAULT = &H400&


Public Function GetSystemError(ByVal Number As Long) As String
    
  Dim sMsgBuf As String * 257, dwLen As Long
  
  dwLen = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM _
    Or FORMAT_MESSAGE_IGNORE_INSERTS Or FORMAT_MESSAGE_MAX_WIDTH_MASK, ByVal 0&, _
    Number, LANG_USER_DEFAULT, ByVal sMsgBuf, 256&, 0&)
  
  If dwLen > 0 Then GetLastErrorStr = LeftB$(sMsgBuf, dwLen)
End Function

#2


谢谢,第二个问题已经解决了,那么第一个问题呢?

#3


这个问题一般是服务器端机器还没有开启,你应该在OnConnect()函数中判断是否连接成功。至于错误,可以用GetLastError()得到,然后,在VC中有一个Error Lookup的工具,可以用来查找该错误号对应于什么错误。

#4


实际上我的连接是成功的,就是说,虽然Connect返回值是0,连接仍然建立了

如果能运行到onconnect那就肯定连接成功了啊,所以我在Connect里判断是否
连接成功

我不知道说清楚了没有

#5


这个问题与socket descriptor的属性阻塞非阻塞有关。

connect操作是阻塞的。调用connect之前先确定一个timeout时间t、设置一个事件变量event、并以event为参数select套接字 FD_CONNECT事件,返回错误之后,获得错误码,如果是不10035—WOULDBLOCK则连接失败。如果是,等待event事件时间t,如果等到,调用WSAEnumNetworkEvents 获得一个LPWSANETWORKEVENTS的指针,通过它的成员iErrorCode
获得connect的错误信息。具体如下:LPWSANETWORKEVENTS->iErrorCode[fd_connect];
如果它为零,则连接成功,如果不为零,则失败,且它就是错误代码。
注意:如果等待函数超时,则需要清除connect操作。时间t的设置与具体情况有关。

#6


36187关注!