ReaderWriterLock.AcquireWriterLock Méthode

Définition

Acquiert le verrou de l’enregistreur.

Surcharges

Nom Description
AcquireWriterLock(Int32)

Acquiert le verrou de l’enregistreur à l’aide d’une Int32 valeur pour le délai d’attente.

AcquireWriterLock(TimeSpan)

Acquiert le verrou de l’enregistreur à l’aide d’une TimeSpan valeur pour le délai d’attente.

AcquireWriterLock(Int32)

Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs

Acquiert le verrou de l’enregistreur à l’aide d’une Int32 valeur pour le délai d’attente.

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

Paramètres

millisecondsTimeout
Int32

Délai d’expiration en millisecondes.

Exceptions

millisecondsTimeout expire avant l’octroi de la demande de verrouillage.

Exemples

L’exemple de code suivant montre comment acquérir et libérer un verrou d’enregistreur et comment gérer l’exception levée lorsqu’une requête expire.

Ce code fait partie d’un exemple plus large fourni pour la ReaderWriterLock classe.

// 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

Remarques

Cette méthode bloque si un autre thread a un verrou de lecteur ou un verrou d’enregistreur. Pour obtenir une description de la façon dont le verrou writer alterne avec plusieurs verrous de lecteur simultanés, consultez la ReaderWriterLock classe.

Un thread qui possède déjà un verrou de lecteur peut acquérir le verrou writer de l’une des deux manières suivantes : en libérant le verrou de lecteur avant d’appeler AcquireWriterLock, ou en appelant UpgradeToWriterLock.

Avertissement

Si un thread appelle AcquireWriterLock alors qu’il a toujours un verrou de lecteur, il bloque sur son propre verrou de lecteur ; si un délai d’attente infini est spécifié, le thread est bloqué. Pour éviter ces interblocages, utilisez cette option IsReaderLockHeld pour déterminer si le thread actuel possède déjà un verrou de lecteur.

AcquireWriterLock prend en charge les demandes de verrouillage de writer-lock récursives. Autrement dit, un thread peut appeler AcquireWriterLock plusieurs fois, ce qui incrémente le nombre de verrous à chaque fois. Vous devez appeler ReleaseWriterLock une seule fois pour chaque fois que vous appelez AcquireWriterLock. Vous pouvez également appeler ReleaseLock pour réduire le nombre de verrous à zéro immédiatement.

Les demandes de verrouillage récursives sont toujours accordées immédiatement, sans placer le thread demandeur dans la file d’attente de l’enregistreur.

Pour connaître les valeurs de délai d’attente valides, consultez ReaderWriterLock.

Voir aussi

S’applique à

AcquireWriterLock(TimeSpan)

Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs
Source:
ReaderWriterLock.cs

Acquiert le verrou de l’enregistreur à l’aide d’une TimeSpan valeur pour le délai d’attente.

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

Paramètres

timeout
TimeSpan

Délai TimeSpan d’attente spécifié.

Exceptions

timeout expire avant l’octroi de la demande de verrouillage.

timeout spécifie une valeur négative autre que -1 millisecondes.

Remarques

Cette méthode bloque si un autre thread a un verrou de lecteur ou un verrou d’enregistreur. Pour obtenir une description de la façon dont le verrou writer alterne avec plusieurs verrous de lecteur simultanés, consultez la ReaderWriterLock classe.

Un thread qui possède déjà un verrou de lecteur peut acquérir le verrou writer de l’une des deux manières suivantes : en libérant le verrou de lecteur avant d’appeler AcquireWriterLock, ou en appelant UpgradeToWriterLock.

Avertissement

Si un thread appelle AcquireWriterLock alors qu’il a toujours un verrou de lecteur, il bloque sur son propre verrou de lecteur ; si un délai d’attente infini est spécifié, le thread est bloqué. Pour éviter ces interblocages, utilisez cette option IsReaderLockHeld pour déterminer si le thread actuel possède déjà un verrou de lecteur.

AcquireWriterLock prend en charge les demandes de verrouillage de writer-lock récursives. Autrement dit, un thread peut appeler AcquireWriterLock plusieurs fois, ce qui incrémente le nombre de verrous à chaque fois. Vous devez appeler ReleaseWriterLock une seule fois pour chaque fois que vous appelez AcquireWriterLock. Vous pouvez également appeler ReleaseLock pour réduire le nombre de verrous à zéro immédiatement.

Les demandes de verrouillage récursives sont toujours accordées immédiatement, sans placer le thread demandeur dans la file d’attente de l’enregistreur.

Pour connaître les valeurs de délai d’attente valides, consultez ReaderWriterLock.

Voir aussi

S’applique à