ReaderWriterLock.AcquireWriterLock Methode

Definition

Erwirbt die Writer-Sperre.

Überlädt

Name Beschreibung
AcquireWriterLock(Int32)

Erwirbt die Writer-Sperre unter Verwendung eines Int32 Werts für das Timeout.

AcquireWriterLock(TimeSpan)

Erwirbt die Writer-Sperre unter Verwendung eines TimeSpan Werts für das Timeout.

AcquireWriterLock(Int32)

Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs

Erwirbt die Writer-Sperre unter Verwendung eines Int32 Werts für das Timeout.

public:
 void AcquireWriterLock(int millisecondsTimeout);
public void AcquireWriterLock(int millisecondsTimeout);
member this.AcquireWriterLock : int -> unit
Public Sub AcquireWriterLock (millisecondsTimeout As Integer)

Parameter

millisecondsTimeout
Int32

Das Timeout in Millisekunden.

Ausnahmen

millisecondsTimeout läuft ab, bevor die Sperranforderung erteilt wird.

Beispiele

Im folgenden Codebeispiel wird gezeigt, wie sie eine Writer-Sperre abrufen und freigeben und wie die Ausnahme behandelt wird, die ausgelöst wird, wenn eine Anforderung zu einem Zeitausfall kommt.

Dieser Code ist Teil eines größeren Beispiels, das für die ReaderWriterLock Klasse bereitgestellt wird.

// The complete code is located in the ReaderWriterLock class topic.
using System;
using System.Threading;

public class Example
{
   static ReaderWriterLock rwl = new ReaderWriterLock();
   // Define the shared resource protected by the ReaderWriterLock.
   static int resource = 0;
' The complete code is located in the ReaderWriterLock class topic.
Imports System.Threading

Public Module Example
   Private rwl As New ReaderWriterLock()
   ' Define the shared resource protected by the ReaderWriterLock.
   Private resource As Integer = 0
// Request and release the writer lock, and handle time-outs.
static void WriteToResource(Random rnd, int timeOut)
{
   try {
      rwl.AcquireWriterLock(timeOut);
      try {
         // It's safe for this thread to access from the shared resource.
         resource = rnd.Next(500);
         Display("writes resource value " + resource);
         Interlocked.Increment(ref writes);
      }
      finally {
         // Ensure that the lock is released.
         rwl.ReleaseWriterLock();
      }
   }
   catch (ApplicationException) {
      // The writer lock request timed out.
      Interlocked.Increment(ref writerTimeouts);
   }
}
' Request and release the writer lock, and handle time-outs.
Sub WriteToResource(rnd As Random, timeOut As Integer)
   Try
      rwl.AcquireWriterLock(timeOut)
      Try
         ' It's safe for this thread to read or write from the shared resource.
         resource = rnd.Next(500)
         Display("writes resource value " & resource)
         Interlocked.Increment(writes)
      Finally
         ' Ensure that the lock is released.
         rwl.ReleaseWriterLock()
      End Try
   Catch ex As ApplicationException
      ' The writer lock request timed out.
      Interlocked.Increment(writerTimeouts)
   End Try
End Sub
}
End Module

Hinweise

Diese Methode blockiert, wenn ein anderer Thread über eine Lese- oder Schreibsperre verfügt. Eine Beschreibung der Art und Weise, wie der Writer die Sperre mit mehreren gleichzeitigen Lesesperren wechselt, finden Sie in der ReaderWriterLock Klasse.

Ein Thread, der bereits über eine Lesesperre verfügt, kann die Writer-Sperre auf eine von zwei Arten abrufen: durch Freigeben der Lesesperre vor dem Aufrufen AcquireWriterLockoder durch Aufrufen UpgradeToWriterLock.

Vorsicht

Wenn ein Thread aufruft AcquireWriterLock , während er noch über eine Lesesperre verfügt, wird er auf seiner eigenen Lesesperre blockiert. Wenn ein unendliches Timeout angegeben ist, wird der Thread inaktiviert. Um solche Deadlocks zu vermeiden, verwenden Sie IsReaderLockHeld diese, um zu bestimmen, ob der aktuelle Thread bereits über eine Lesesperre verfügt.

AcquireWriterLock unterstützt rekursive Writer-Lock-Anforderungen. Das heißt, ein Thread kann mehrmals aufgerufen werden AcquireWriterLock , wodurch die Sperranzahl jedes Mal erhöht wird. Sie müssen jedes Mal einmal anrufen ReleaseWriterLock , wenn Sie anrufen AcquireWriterLock. Alternativ können Sie aufrufen ReleaseLock , um die Sperranzahl sofort auf Null zu reduzieren.

Rekursive Sperranforderungen werden immer sofort gewährt, ohne den anfordernden Thread in der Writer-Warteschlange zu platzieren.

Gültige Timeoutwerte finden Sie unter ReaderWriterLock.

Weitere Informationen

Gilt für:

AcquireWriterLock(TimeSpan)

Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs
Quelle:
ReaderWriterLock.cs

Erwirbt die Writer-Sperre unter Verwendung eines TimeSpan Werts für das Timeout.

public:
 void AcquireWriterLock(TimeSpan timeout);
public void AcquireWriterLock(TimeSpan timeout);
member this.AcquireWriterLock : TimeSpan -> unit
Public Sub AcquireWriterLock (timeout As TimeSpan)

Parameter

timeout
TimeSpan

Die TimeSpan Angabe des Timeoutzeitraums.

Ausnahmen

timeout läuft ab, bevor die Sperranforderung erteilt wird.

timeout Gibt einen anderen negativen Wert als -1 Millisekunden an.

Hinweise

Diese Methode blockiert, wenn ein anderer Thread über eine Lese- oder Schreibsperre verfügt. Eine Beschreibung der Art und Weise, wie der Writer die Sperre mit mehreren gleichzeitigen Lesesperren wechselt, finden Sie in der ReaderWriterLock Klasse.

Ein Thread, der bereits über eine Lesesperre verfügt, kann die Writer-Sperre auf eine von zwei Arten abrufen: durch Freigeben der Lesesperre vor dem Aufrufen AcquireWriterLockoder durch Aufrufen UpgradeToWriterLock.

Vorsicht

Wenn ein Thread aufruft AcquireWriterLock , während er noch über eine Lesesperre verfügt, wird er auf seiner eigenen Lesesperre blockiert. Wenn ein unendliches Timeout angegeben ist, wird der Thread inaktiviert. Um solche Deadlocks zu vermeiden, verwenden Sie IsReaderLockHeld diese, um zu bestimmen, ob der aktuelle Thread bereits über eine Lesesperre verfügt.

AcquireWriterLock unterstützt rekursive Writer-Lock-Anforderungen. Das heißt, ein Thread kann mehrmals aufgerufen werden AcquireWriterLock , wodurch die Sperranzahl jedes Mal erhöht wird. Sie müssen jedes Mal einmal anrufen ReleaseWriterLock , wenn Sie anrufen AcquireWriterLock. Alternativ können Sie aufrufen ReleaseLock , um die Sperranzahl sofort auf Null zu reduzieren.

Rekursive Sperranforderungen werden immer sofort gewährt, ohne den anfordernden Thread in der Writer-Warteschlange zu platzieren.

Gültige Timeoutwerte finden Sie unter ReaderWriterLock.

Weitere Informationen

Gilt für: