Condividi tramite


Funzione WaitForSingleObject (synchapi.h)

Attende che l'oggetto specificato non sia nello stato segnalato o che l'intervallo di timeout scade.

Per immettere uno stato di attesa avvisabile, usare la funzione WaitForSingleObjectEx. Per attendere più oggetti, usare WaitForMultipleObjects.

Sintassi

DWORD WaitForSingleObject(
  [in] HANDLE hHandle,
  [in] DWORD  dwMilliseconds
);

Parametri

[in] hHandle

Handle per l'oggetto. Per un elenco dei tipi di oggetto i cui handle possono essere specificati, vedere la sezione Osservazioni seguente.

Se questo handle viene chiuso mentre l'attesa è ancora in sospeso, il comportamento della funzione non è definito.

L'handle deve avere il diritto di accesso SYNCHRONIZE . Per altre informazioni, vedere Standard Access Rights.

[in] dwMilliseconds

Intervallo di timeout, espresso in millisecondi. Se viene specificato un valore diverso da zero, la funzione attende finché l'oggetto non viene segnalato o l'intervallo trascorso. Se dwMilliseconds è zero, la funzione non immette uno stato di attesa se l'oggetto non viene segnalato; restituisce sempre immediatamente. Se dwMilliseconds è INFINITE, la funzione restituirà solo quando l'oggetto viene segnalato.

Windows XP, Windows Server 2003, Windows Vista, Windows 7, Windows Server 2008 e Windows Server 2008 R2: Il valore dwMilliseconds include il tempo impiegato in stati a basso consumo. Ad esempio, il timeout continua a contare mentre il computer è in stato di sospensione.

Windows 8 e versioni successive, Windows Server 2012 e versioni successive: Il valore dwMilliseconds non include il tempo impiegato in stati a basso consumo. Ad esempio, il timeout non continua a contare mentre il computer è in stato di sospensione.

Valore restituito

Se la funzione ha esito positivo, il valore restituito indica l'evento che ha causato la restituzione della funzione. Può essere uno dei valori seguenti.

Codice/valore restituito Descrizione
WAIT_ABANDONED
0x00000080L
L'oggetto specificato è un oggetto mutex che non è stato rilasciato dal thread che appartiene all'oggetto mutex prima che il thread proprietario venga terminato. La proprietà dell'oggetto mutex viene concessa al thread chiamante e lo stato mutex è impostato su non firmato.

Se il mutex proteggeva le informazioni sullo stato permanenti, è necessario verificarne la coerenza.

WAIT_OBJECT_0
0x00000000L
Lo stato dell'oggetto specificato viene segnalato.
WAIT_TIMEOUT
0x00000102L
Intervallo di timeout trascorso e lo stato dell'oggetto non è firmato.
WAIT_FAILED
(DWORD)0xFFFFFFFF
La funzione non è riuscita. Per ottenere informazioni estese sull'errore, chiamare GetLastError.

Osservazioni

La funzione WaitForSingleObject controlla lo stato corrente dell'oggetto specificato. Se lo stato dell'oggetto non è firmato, il thread chiamante entra nello stato di attesa fino a quando l'oggetto non viene segnalato o scade l'intervallo di timeout.

La funzione modifica lo stato di alcuni tipi di oggetti di sincronizzazione. La modifica viene eseguita solo per l'oggetto il cui stato segnalato ha causato la restituzione della funzione. Ad esempio, il conteggio di un oggetto semaforo viene ridotto di uno.

La funzione WaitForSingleObject può attendere gli oggetti seguenti:

  • Notifica di modifica
  • Input della console
  • Evento
  • Notifica delle risorse di memoria
  • Mutex
  • Processo
  • Semaforo
  • Filo
  • Timer waitable
Prestare attenzione quando si chiamano le funzioni di attesa e il codice che crea direttamente o indirettamente finestre. Se un thread crea finestre, deve elaborare i messaggi. Le trasmissioni di messaggi vengono inviate a tutte le finestre del sistema. Un thread che usa una funzione di attesa con un intervallo di timeout INFINITE può causare il deadlock del sistema. Due esempi di codice che creano indirettamente finestre sono DDE e la funzione CoInitialize. Pertanto, se si dispone di un thread che crea finestre, usare MsgWaitForMultipleObjects o MsgWaitForMultipleObjectsEx, anziché WaitForSingleObject.

Esempi

Per un esempio, vedere Using Mutex Objects.

Fabbisogno

Requisito Valore
client minimo supportato Windows XP [app desktop | App UWP]
server minimo supportato Windows Server 2003 [app desktop | App UWP]
piattaforma di destinazione Finestre
intestazione synchapi.h (include Windows.h in Windows Server 2003, Windows Vista, Windows 7, Windows Server 2008 Windows Server 2008 R2)
libreria Kernel32.lib
dll Kernel32.dll

Vedere anche

funzioni di sincronizzazione

funzioni di attesa