Classe CSocket
Deriva da CAsyncSocket, eredita il relativo incapsulamento di Windows Sockets API e rappresenta un livello più elevato di astrazione che quello di un oggetto CAsyncSocket.
class CSocket : public CAsyncSocket
Membri
Costruttori pubblici
Nome |
Descrizione |
---|---|
Costruisce un oggetto CSocket. |
Metodi pubblici
Nome |
Descrizione |
---|---|
Associa gli handle SOCKET a un oggetto CSocket. |
|
Annulla una chiamata di blocco che è in corso. |
|
Crea un socket. |
|
Restituisce un puntatore a un oggetto CSocket, dato un handle SOCKET. |
|
Determina se una chiamata di blocco è in corso. |
Metodi protetti
Nome |
Descrizione |
---|---|
Chiamato per elaborare in attesa dei messaggi mentre attesa di una chiamata di blocco per completare. |
Note
Funzionamento diCSocket con le classi CSocketFile e CArchive per gestire l'invio e la ricezione di dati.
Un oggetto CSocket fornisce anche il blocco, che è essenziale all'operazione sincrona CArchive. Il blocco viene eseguito, come Receive, Send, ReceiveFrom, SendToe Accept (interamente ereditato da CAsyncSocket), non restituisce un errore WSAEWOULDBLOCK in CSocket. Invece, queste funzioni attende fino al completamento di quest'ultima. Inoltre, la chiamata originale termina con l'errore WSAEINTR se CancelBlockingCall viene chiamato quando una di queste funzioni è bloccato.
Per utilizzare un oggetto CSocket, chiamare il costruttore, la chiamata Create per creare un handle sottostante SOCKET (tipo SOCKET). I parametri predefiniti Create creano un socket di flusso, ma se non si utilizza un socket a un oggetto CArchive, è possibile specificare un parametro per creare un socket di datagramma invece, o associare a una porta specifica per creare un socket del server. Connettersi a un socket client utilizzando Connect lato client e Accept lato server. Creare quindi un oggetto CSocketFile un oggetto e associarlo all'oggetto CSocket nel costruttore CSocketFile. Successivamente, creare un oggetto CArchive per l'invio e uno per ricevere dati (se necessario), quindi associli con l'oggetto CSocketFile nel costruttore CArchive. Quando le comunicazioni completate, eliminare CArchive, CSocketFilee gli oggetti CSocket. Il tipo di dati SOCKET è descritto nell'articolo Windows Sockets: sfondo.
Quando si utilizza CArchive con CSocketFile e CSocket, potrebbe verificarsi una situazione in cui CSocket::Receive immette un ciclo (da PumpMessages(FD_READ)) che attende la quantità richiesta di byte. Questo perché i socket di Windows consente solo una chiamata di recv per notifica di FD_READ, ma CSocketFile e CSocket consentono più chiamate di recv per FD_READ. Se viene visualizzato un FD_READ quando non vi sono dati da leggere, verrà bloccato. Se non si ottengono mai un altro FD_READ, l'applicazione termina la sessione di per comunicare su socket.
È possibile risolvere questo problema come segue. Nel metodo OnReceive della classe di socket, chiamata CAsyncSocket::IOCtl(FIONREAD, ...) prima di chiamare il metodo Serialize della classe di messaggio quando i dati previsti da leggere da socket supera la dimensione di un pacchetto TCP (Maximum Transmission Unit il supporto della rete, in genere di almeno 1096 byte). Se la dimensione dei dati disponibili meno di quanto necessario, aspetti tutti i dati da ricevere solo e quindi avviare l'operazione di lettura.
Nell'esempio seguente, m_dwExpected è il numero di byte approssimativo che l'utente prevede di ricevere. Si presuppone che lo dichiara altrove nel codice.
void CChatSocket::OnReceive(int nErrorCode)
{
CSocket::OnReceive(nErrorCode);
DWORD dwReceived;
if (IOCtl(FIONREAD, &dwReceived))
{
if (dwReceived >= m_dwExpected) // Process only if you have enough data
m_pDoc->ProcessPendingRead();
}
else
{
// Error handling here
}
}
Nota
In utilizzare sockets MFC nei thread secondari in un'applicazione collegata in modo statico MFC, è necessario chiamare AfxSocketInit in ogni thread che utilizza i socket per inizializzare le librerie di socket.Per impostazione predefinita, AfxSocketInit viene chiamato solo nel thread primario.
Per ulteriori informazioni, vedere In Windows Sockets MFC, Windows Sockets: Utilizzo di socket con gli archivi, Windows Sockets: Come socket con il lavoro degli archivi, Windows Sockets: sequenza di operazioni, Windows Sockets: Esempio di socket utilizzando gli archivi.
Gerarchia di ereditarietà
CSocket
Requisiti
intestazione: afxsock.h