Condividi tramite


Classe di CSemaphore

Un oggetto di classe CSemaphore "rappresenta un semaforo" — un oggetto di sincronizzazione che consente a un numero limitato di thread in uno o più processi accedere a un oggetto gestisce un conteggio del numero di thread attualmente che accedono a una risorsa specificata.

class CSemaphore : public CSyncObject

Membri

78w43c88.collapse_all(it-it,VS.110).gifCostruttori pubblici

Nome

Descrizione

CSemaphore::CSemaphore

Costruisce un oggetto CSemaphore.

Note

I semafori sono utili per controllare l'accesso a una risorsa condivisa che può supportare solo un numero limitato di utenti.Il conteggio corrente dell'oggetto CSemaphore è il numero di utenti aggiuntivi consentiti.Quando il conteggio raggiunge lo zero, qualsiasi tentativo di utilizzare la risorsa controllata dall'oggetto CSemaphore verranno inseriti in una coda e di attesa del sistema finché non scadano o il conteggio aumentare superiore a 0.Numero massimo di utenti che possono accedere alla risorsa controllata contemporaneamente viene specificato durante la costruzione dell'oggetto CSemaphore.

Per utilizzare un oggetto CSemaphore , costruire l'oggetto CSemaphore quando necessario.Specificare il nome del semaforo che si desidera attendere su e che l'applicazione deve inizialmente possederla.È quindi possibile accedere al semaforo al completamento del costruttore.Chiamare CSyncObject::Unlock al termine di accedere alla risorsa controllata.

Un metodo alternativo per gli oggetti CSemaphore è possibile aggiungere una variabile di tipo CSemaphore come un membro dati alla classe che si desidera controllare.Durante la costruzione dell'oggetto selezionato, chiamare il costruttore del membro dati CSemaphore che specifica il numero di accesso iniziale, il massimo conteggio di accesso, il nome del semaforo (se verrà utilizzato oltre i limiti dei processi) e gli attributi di sicurezza desiderati.

Per accedere alle risorse controllate dagli oggetti CSemaphore in questo modo, prima di creare una variabile di tipo CSingleLock o per immettere CMultiLock nella funzione membro di accesso delle risorse.Chiamare la funzione membro Lock dell'oggetto di blocco (ad esempio, CSingleLock::Lock).In questa fase, il thread accederà alla risorsa, attendere che la risorsa da rilasciare e accederà, o attenderà la risorsa da rilasciare e scaduto, non completate per accedere alla risorsa.Tuttavia, la risorsa è stata accedere in modo thread-safe.Per rilasciare la risorsa, utilizzare la funzione membro Unlock dell'oggetto di blocco (ad esempio, CSingleLock::Unlock), o consentire all'oggetto del blocco alla UIambito.

In alternativa, è possibile creare un oggetto CSemaphore autonomo e lo si accede in modo esplicito prima di tentare di accedere alla risorsa controllata.Questo metodo, mentre pulita che qualcuno che legge il codice sorgente, è ad errori più soggetto.

Per ulteriori informazioni su come utilizzare gli oggetti CSemaphore , vedere l'articolo multithreading: Utilizzo delle classi di sincronizzazione.

Gerarchia di ereditarietà

CObject

CSyncObject

CSemaphore

Requisiti

Header: afxmt.h

Vedere anche

Riferimenti

Classe di CSyncObject

Grafico della gerarchia