在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里判断是否
连接成功
我不知道说清楚了没有
如果能运行到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的设置与具体情况有关。
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里判断是否
连接成功
我不知道说清楚了没有
如果能运行到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的设置与具体情况有关。
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关注!