CAsyncSocket::OnSend
Appelé par l'infrastructure pour informer le socket qu'il peut à présent envoyer des données en appelant la fonction membre de Envoyer .
virtual void OnSend(
int nErrorCode
);
Paramètres
nErrorCode
l'erreur la plus récente sur un socket. Les codes d'erreur suivante s'appliquent à OnSend la fonction membre :0 La fonction exécutée avec succès.
WSAENETDOWN que l'implémentation de Windows Sockets l'a détecté que le sous-système réseau a échoué.
Notes
Pour plus d'informations, consultez Windows Sockets : notifications de socket.
Exemple
// CMyAsyncSocket is derived from CAsyncSocket and defines the
// following variables:
// CString m_sendBuffer; //for async send
// int m_nBytesSent;
// int m_nBytesBufferSize;
void CMyAsyncSocket::OnSend(int nErrorCode)
{
while (m_nBytesSent < m_nBytesBufferSize)
{
int dwBytes;
if ((dwBytes = Send((LPCTSTR)m_sendBuffer + m_nBytesSent,
m_nBytesBufferSize - m_nBytesSent)) == SOCKET_ERROR)
{
if (GetLastError() == WSAEWOULDBLOCK)
{
break;
}
else
{
TCHAR szError[256];
_stprintf_s(szError, _T("Server Socket failed to send: %d"),
GetLastError());
Close();
AfxMessageBox (szError);
}
}
else
{
m_nBytesSent += dwBytes;
}
}
if (m_nBytesSent == m_nBytesBufferSize)
{
m_nBytesSent = m_nBytesBufferSize = 0;
m_sendBuffer = _T("");
}
CAsyncSocket::OnSend(nErrorCode);
}
Configuration requise
Header: afxsock.h