ReaderWriterLock.WriterSeqNum Eigenschap
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.
Hiermee haalt u het huidige volgnummer op.
public:
property int WriterSeqNum { int get(); };
public int WriterSeqNum { get; }
member this.WriterSeqNum : int
Public ReadOnly Property WriterSeqNum As Integer
Waarde van eigenschap
Het huidige volgnummer.
Voorbeelden
In het volgende codevoorbeeld ziet u hoe u de WriterSeqNum eigenschap en de AnyWritersSince methode gebruikt om te bepalen of een andere thread de schrijververgrendeling heeft verkregen voor de beveiligde resource, omdat de huidige thread de schrijververgrendeling het laatst heeft bewaard.
Deze code maakt deel uit van een groter voorbeeld voor de ReaderWriterLock klasse.
// 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
// Release all locks and later restores the lock state.
// Uses sequence numbers to determine whether another thread has
// obtained a writer lock since this thread last accessed the resource.
static void ReleaseRestore(Random rnd, int timeOut)
{
int lastWriter;
try {
rwl.AcquireReaderLock(timeOut);
try {
// It's safe for this thread to read from the shared resource,
// so read and cache the resource value.
int resourceValue = resource; // Cache the resource value.
Display("reads resource value " + resourceValue);
Interlocked.Increment(ref reads);
// Save the current writer sequence number.
lastWriter = rwl.WriterSeqNum;
// Release the lock and save a cookie so the lock can be restored later.
LockCookie lc = rwl.ReleaseLock();
// Wait for a random interval and then restore the previous state of the lock.
Thread.Sleep(rnd.Next(250));
rwl.RestoreLock(ref lc);
// Check whether other threads obtained the writer lock in the interval.
// If not, then the cached value of the resource is still valid.
if (rwl.AnyWritersSince(lastWriter)) {
resourceValue = resource;
Interlocked.Increment(ref reads);
Display("resource has changed " + resourceValue);
}
else {
Display("resource has not changed " + resourceValue);
}
}
finally {
// Ensure that the lock is released.
rwl.ReleaseReaderLock();
}
}
catch (ApplicationException) {
// The reader lock request timed out.
Interlocked.Increment(ref readerTimeouts);
}
}
' Release all locks and later restores the lock state.
' Uses sequence numbers to determine whether another thread has
' obtained a writer lock since this thread last accessed the resource.
Sub ReleaseRestore(rnd As Random ,timeOut As Integer)
Dim lastWriter As Integer
Try
rwl.AcquireReaderLock(timeOut)
Try
' It's safe for this thread to read from the shared resource,
' so read and cache the resource value.
Dim resourceValue As Integer = resource
Display("reads resource value " & resourceValue)
Interlocked.Increment(reads)
' Save the current writer sequence number.
lastWriter = rwl.WriterSeqNum
' Release the lock and save a cookie so the lock can be restored later.
Dim lc As LockCookie = rwl.ReleaseLock()
' Wait for a random interval and then restore the previous state of the lock.
Thread.Sleep(rnd.Next(250))
rwl.RestoreLock(lc)
' Check whether other threads obtained the writer lock in the interval.
' If not, then the cached value of the resource is still valid.
If rwl.AnyWritersSince(lastWriter) Then
resourceValue = resource
Interlocked.Increment(reads)
Display("resource has changed " & resourceValue)
Else
Display("resource has not changed " & resourceValue)
End If
Finally
' Ensure that the lock is released.
rwl.ReleaseReaderLock()
End Try
Catch ex As ApplicationException
' The reader lock request timed out.
Interlocked.Increment(readerTimeouts)
End Try
End Sub
}
End Module
Opmerkingen
Het volgnummer neemt toe wanneer een thread de schrijfvergrendeling verkrijgt. U kunt het volgnummer opslaan en op een later tijdstip doorgeven AnyWritersSince als u wilt bepalen of andere threads de schrijfvergrendeling in de tussentijd hebben verkregen.
U kunt de WriterSeqNum prestaties van toepassingen verbeteren. Een thread kan bijvoorbeeld de informatie in de cache opslaan die wordt verkregen tijdens het vasthouden van een lezervergrendeling. Nadat de vergrendeling is vrijgegeven en later opnieuw is geïnstalleerd, kan de thread bepalen of andere threads naar de resource zijn geschreven door aan te roepen AnyWritersSince. Zo niet, dan kunnen de gegevens in de cache worden gebruikt. Deze techniek is handig bij het lezen van de informatie die door de vergrendeling wordt beschermd, is duur; Bijvoorbeeld het uitvoeren van een databasequery.
De beller moet een lezervergrendeling of een schrijfvergrendeling bevatten om het volgnummer nuttig te kunnen maken.
Van toepassing op
Zie ook
- Het Beheerd Draadbeheer
- ReaderWriterLock