Udostępnij za pośrednictwem


CAsyncSocket::OnReceive

Wywołana w ramach powiadomienia tego gniazda, istnieją dane w buforze, które mogą być pobierane przez wywołanie odbioru funkcji składowej.

virtual void OnReceive(
   int nErrorCode 
);

Parametry

  • nErrorCode
    Ostatni błąd na gnieździe.Następujące kody błędów, które stosuje się do OnReceive Członkowskich funkcji:

    • 0 Funkcja została wykonana pomyślnie.

    • WSAENETDOWN implementacja Windows Sockets wykrył, że podsystem sieci nie powiodło się.

Uwagi

Aby uzyskać więcej informacji, zobacz Windows Sockets: gniazdo powiadomienia.

Przykład

void CMyAsyncSocket::OnReceive(int nErrorCode)   // CMyAsyncSocket is 
                                                // derived from CAsyncSocket
{
   static int i = 0;

   i++;

   TCHAR buff[4096];
   int nRead;
   nRead = Receive(buff, 4096); 

   switch (nRead)
   {
      case 0:
        Close();
        break;
      case SOCKET_ERROR:
        if (GetLastError() != WSAEWOULDBLOCK) 
        {
          AfxMessageBox (_T("Error occurred"));
          Close();
        }
        break;
      default:
        buff[nRead] = _T('\0'); //terminate the string
        CString szTemp(buff);
        m_strRecv += szTemp;   // m_strRecv is a CString declared 
                        // in CMyAsyncSocket
        if (szTemp.CompareNoCase(_T("bye")) == 0)
        {
           ShutDown();
           s_eventDone.SetEvent();
        }
   }
   CAsyncSocket::OnReceive(nErrorCode);
}

Wymagania

Nagłówek: afxsock.h

Zobacz też

Informacje

Klasa CAsyncSocket

Wykres hierarchii

CAsyncSocket::GetLastError

CAsyncSocket::OnAccept

CAsyncSocket::OnClose

CAsyncSocket::OnConnect

CAsyncSocket::OnOutOfBandData

CAsyncSocket::OnSend

CAsyncSocket::Receive