ManualResetEventSlim Klas
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Vertegenwoordigt een threadsynchronisatiegebeurtenis die, indien gesignaleerd, handmatig opnieuw moet worden ingesteld. Deze klasse is een lichtgewicht alternatief voor ManualResetEvent.
public ref class ManualResetEventSlim : IDisposable
public class ManualResetEventSlim : IDisposable
[System.Runtime.InteropServices.ComVisible(false)]
public class ManualResetEventSlim : IDisposable
type ManualResetEventSlim = class
interface IDisposable
[<System.Runtime.InteropServices.ComVisible(false)>]
type ManualResetEventSlim = class
interface IDisposable
Public Class ManualResetEventSlim
Implements IDisposable
- Overname
-
ManualResetEventSlim
- Kenmerken
- Implementeringen
Voorbeelden
In het volgende voorbeeld ziet u hoe u een ManualResetEventSlim.
using System;
using System.Threading;
using System.Threading.Tasks;
class MRESDemo
{
static void Main()
{
MRES_SetWaitReset();
MRES_SpinCountWaitHandle();
}
// Demonstrates:
// ManualResetEventSlim construction
// ManualResetEventSlim.Wait()
// ManualResetEventSlim.Set()
// ManualResetEventSlim.Reset()
// ManualResetEventSlim.IsSet
static void MRES_SetWaitReset()
{
ManualResetEventSlim mres1 = new ManualResetEventSlim(false); // initialize as unsignaled
ManualResetEventSlim mres2 = new ManualResetEventSlim(false); // initialize as unsignaled
ManualResetEventSlim mres3 = new ManualResetEventSlim(true); // initialize as signaled
// Start an asynchronous Task that manipulates mres3 and mres2
var observer = Task.Factory.StartNew(() =>
{
mres1.Wait();
Console.WriteLine("observer sees signaled mres1!");
Console.WriteLine("observer resetting mres3...");
mres3.Reset(); // should switch to unsignaled
Console.WriteLine("observer signalling mres2");
mres2.Set();
});
Console.WriteLine("main thread: mres3.IsSet = {0} (should be true)", mres3.IsSet);
Console.WriteLine("main thread signalling mres1");
mres1.Set(); // This will "kick off" the observer Task
mres2.Wait(); // This won't return until observer Task has finished resetting mres3
Console.WriteLine("main thread sees signaled mres2!");
Console.WriteLine("main thread: mres3.IsSet = {0} (should be false)", mres3.IsSet);
// It's good form to Dispose() a ManualResetEventSlim when you're done with it
observer.Wait(); // make sure that this has fully completed
mres1.Dispose();
mres2.Dispose();
mres3.Dispose();
}
// Demonstrates:
// ManualResetEventSlim construction w/ SpinCount
// ManualResetEventSlim.WaitHandle
static void MRES_SpinCountWaitHandle()
{
// Construct a ManualResetEventSlim with a SpinCount of 1000
// Higher spincount => longer time the MRES will spin-wait before taking lock
ManualResetEventSlim mres1 = new ManualResetEventSlim(false, 1000);
ManualResetEventSlim mres2 = new ManualResetEventSlim(false, 1000);
Task bgTask = Task.Factory.StartNew(() =>
{
// Just wait a little
Thread.Sleep(100);
// Now signal both MRESes
Console.WriteLine("Task signalling both MRESes");
mres1.Set();
mres2.Set();
});
// A common use of MRES.WaitHandle is to use MRES as a participant in
// WaitHandle.WaitAll/WaitAny. Note that accessing MRES.WaitHandle will
// result in the unconditional inflation of the underlying ManualResetEvent.
WaitHandle.WaitAll(new WaitHandle[] { mres1.WaitHandle, mres2.WaitHandle });
Console.WriteLine("WaitHandle.WaitAll(mres1.WaitHandle, mres2.WaitHandle) completed.");
// Clean up
bgTask.Wait();
mres1.Dispose();
mres2.Dispose();
}
}
Imports System.Threading
Imports System.Threading.Tasks
Module MRESDemo
Sub Main()
End Sub
' Demonstrates:
' ManualResetEventSlim construction
' ManualResetEventSlim.Wait()
' ManualResetEventSlim.Set()
' ManualResetEventSlim.Reset()
' ManualResetEventSlim.IsSet
Private Sub MRES_SetWaitReset()
' initialize as unsignaled
Dim mres1 As New ManualResetEventSlim(False)
' initialize as unsignaled
Dim mres2 As New ManualResetEventSlim(False)
' initialize as signaled
Dim mres3 As New ManualResetEventSlim(True)
' Start an asynchronous Task that manipulates mres3 and mres2
Dim observer = Task.Factory.StartNew(
Sub()
mres1.Wait()
Console.WriteLine("observer sees signaled mres1!")
Console.WriteLine("observer resetting mres3...")
mres3.Reset()
' should switch to unsignaled
Console.WriteLine("observer signalling mres2")
mres2.[Set]()
End Sub)
Console.WriteLine("main thread: mres3.IsSet = {0} (should be true)", mres3.IsSet)
Console.WriteLine("main thread signalling mres1")
mres1.[Set]()
' This will "kick off" the observer Task
mres2.Wait()
' This won't return until observer Task has finished resetting mres3
Console.WriteLine("main thread sees signaled mres2!")
Console.WriteLine("main thread: mres3.IsSet = {0} (should be false)", mres3.IsSet)
' make sure that observer has fully completed
observer.Wait()
' It's good form to Dispose() a ManualResetEventSlim when you're done with it
mres1.Dispose()
mres2.Dispose()
mres3.Dispose()
End Sub
' Demonstrates:
' ManualResetEventSlim construction w/ SpinCount
' ManualResetEventSlim.WaitHandle
Private Sub MRES_SpinCountWaitHandle()
' Construct a ManualResetEventSlim with a SpinCount of 1000
' Higher spincount => longer time the MRES will spin-wait before taking lock
Dim mres1 As New ManualResetEventSlim(False, 1000)
Dim mres2 As New ManualResetEventSlim(False, 1000)
Dim bgTask As Task = Task.Factory.StartNew(
Sub()
' Just wait a little
Thread.Sleep(100)
' Now signal both MRESes
Console.WriteLine("Task signalling both MRESes")
mres1.[Set]()
mres2.[Set]()
End Sub)
' A common use of MRES.WaitHandle is to use MRES as a participant in
' WaitHandle.WaitAll/WaitAny. Note that accessing MRES.WaitHandle will
' result in the unconditional inflation of the underlying ManualResetEvent.
WaitHandle.WaitAll(New WaitHandle() {mres1.WaitHandle, mres2.WaitHandle})
Console.WriteLine("WaitHandle.WaitAll(mres1.WaitHandle, mres2.WaitHandle) completed.")
' Wait for bgTask to complete and clean up
bgTask.Wait()
mres1.Dispose()
mres2.Dispose()
End Sub
End Module
Opmerkingen
U kunt deze klasse gebruiken voor betere prestaties dan ManualResetEvent wanneer wachttijden naar verwachting zeer kort zijn en wanneer de gebeurtenis geen procesgrens overschrijdt. ManualResetEventSlim gebruikt bezet draaien gedurende een korte tijd terwijl wordt gewacht tot de gebeurtenis wordt gesignaleerd. Wanneer wachttijden kort zijn, kan het draaien veel goedkoper zijn dan wachten met behulp van wachtgrepen. Als de gebeurtenis echter niet binnen een bepaalde periode wordt gesignaleerd, ManualResetEventSlim gaat u terug naar een normale gebeurtenishandler.
Note
In .NET Core en .NET 5+ is de standaard kringwachttijd kort: op volgorde van 10 microseconden, afhankelijk van het platform en de processor. Als u verwacht dat wachttijden veel langer zijn dan dat, kunt u deze klasse nog steeds gebruiken in plaats van ManualResetEvent (mogelijk geconfigureerd met minder of geen spin-waiting). Het prestatievoordeel zou echter waarschijnlijk slechts marginaal zijn.
Constructors
| Name | Description |
|---|---|
| ManualResetEventSlim() |
Initialiseert een nieuw exemplaar van de ManualResetEventSlim klasse met een initiële status van niet-ondertekend. |
| ManualResetEventSlim(Boolean, Int32) |
Initialiseert een nieuw exemplaar van de ManualResetEventSlim klasse met een Booleaanse waarde die aangeeft of de initiële status moet worden ingesteld op gesignaleerd en een opgegeven aantal spinnen. |
| ManualResetEventSlim(Boolean) |
Initialiseert een nieuw exemplaar van de ManualResetEventSlim klasse met een Booleaanse waarde die aangeeft of de initiële status moet worden ingesteld op gesignaleerd. |
Eigenschappen
| Name | Description |
|---|---|
| IsSet |
Hiermee wordt aangegeven of de gebeurtenis is ingesteld. |
| SpinCount |
Hiermee haalt u het aantal kringwachttijden op dat plaatsvindt voordat u terugvalt op een op kernel gebaseerde wachtbewerking. |
| WaitHandle |
Hiermee wordt het onderliggende WaitHandle object voor dit ManualResetEventSlimobject opgehaald. |
Methoden
| Name | Description |
|---|---|
| Dispose() |
Alle resources die door het huidige exemplaar van de ManualResetEventSlim klasse worden gebruikt, worden vrijgegeven. |
| Dispose(Boolean) |
Releases van de niet-beheerde resources die worden gebruikt door de ManualResetEventSlim, en optioneel releases van de beheerde resources. |
| Equals(Object) |
Bepaalt of het opgegeven object gelijk is aan het huidige object. (Overgenomen van Object) |
| GetHashCode() |
Fungeert als de standaardhashfunctie. (Overgenomen van Object) |
| GetType() |
Hiermee haalt u de Type huidige instantie op. (Overgenomen van Object) |
| MemberwiseClone() |
Hiermee maakt u een ondiepe kopie van de huidige Object. (Overgenomen van Object) |
| Reset() |
Hiermee stelt u de status van de gebeurtenis in op niet-ondertekend, waardoor threads worden geblokkeerd. |
| Set() |
Hiermee stelt u de status van de gebeurtenis in op signalering, waardoor een of meer threads die wachten op de gebeurtenis kunnen doorgaan. |
| ToString() |
Retourneert een tekenreeks die het huidige object vertegenwoordigt. (Overgenomen van Object) |
| Wait() |
Hiermee blokkeert u de huidige thread totdat de huidige ManualResetEventSlim is ingesteld. |
| Wait(CancellationToken) |
Blokkeert de huidige thread totdat de stroom ManualResetEventSlim een signaal ontvangt, terwijl een CancellationToken. |
| Wait(Int32, CancellationToken) |
Hiermee blokkeert u de huidige thread totdat de huidige ManualResetEventSlim is ingesteld, met behulp van een 32-bits geheel getal dat is ondertekend om het tijdsinterval te meten, terwijl u een CancellationToken. |
| Wait(Int32) |
Hiermee blokkeert u de huidige thread totdat de huidige ManualResetEventSlim is ingesteld, met behulp van een 32-bits geheel getal dat is ondertekend om het tijdsinterval te meten. |
| Wait(TimeSpan, CancellationToken) |
Hiermee blokkeert u de huidige thread totdat de huidige ManualResetEventSlim is ingesteld, met behulp van een TimeSpan om het tijdsinterval te meten, terwijl u een CancellationToken. |
| Wait(TimeSpan) |
Hiermee blokkeert u de huidige thread totdat de huidige ManualResetEventSlim is ingesteld, met behulp van een TimeSpan om het tijdsinterval te meten. |
Van toepassing op
Veiligheid thread
Alle openbare en beveiligde leden van ManualResetEventSlim zijn thread-veilig en kunnen gelijktijdig worden gebruikt vanuit meerdere threads, met uitzondering van Verwijderen, die alleen mogen worden gebruikt wanneer alle andere bewerkingen op het ManualResetEventSlim gebied zijn voltooid en Opnieuw instellen, die alleen mogen worden gebruikt wanneer er geen andere threads toegang hebben tot de gebeurtenis.