ReaderWriterLock.AcquireReaderLock Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Získá zámek čtečky.
Přetížení
AcquireReaderLock(Int32) |
Získá zámek čtečky s použitím Int32 hodnoty pro časový limit. |
AcquireReaderLock(TimeSpan) |
Získá zámek čtečky s použitím TimeSpan hodnoty pro časový limit. |
AcquireReaderLock(Int32)
Získá zámek čtečky s použitím Int32 hodnoty pro časový limit.
public:
void AcquireReaderLock(int millisecondsTimeout);
public void AcquireReaderLock (int millisecondsTimeout);
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public void AcquireReaderLock (int millisecondsTimeout);
member this.AcquireReaderLock : int -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("browser")>]
member this.AcquireReaderLock : int -> unit
Public Sub AcquireReaderLock (millisecondsTimeout As Integer)
Parametry
- millisecondsTimeout
- Int32
Časový limit je v milisekundách.
- Atributy
Výjimky
millisecondsTimeout
vyprší před udělením žádosti o zámek.
Příklady
Následující příklad kódu ukazuje, jak získat a uvolnit zámek čtenáře a jak zpracovat výjimku vyvolánou při vypršení časového limitu požadavku.
Tento kód je součástí většího příkladu zadaného ReaderWriterLock pro třídu.
// The complete code is located in the ReaderWriterLock
// class topic.
using namespace System;
using namespace System::Threading;
public ref class Test
{
public:
// Declaring the ReaderWriterLock at the class level
// makes it visible to all threads.
static ReaderWriterLock^ rwl = gcnew ReaderWriterLock;
// For this example, the shared resource protected by the
// ReaderWriterLock is just an integer.
static int resource = 0;
// 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
// Shows how to request and release a reader lock, and
// how to handle time-outs.
static void ReadFromResource( int timeOut )
{
try
{
rwl->AcquireReaderLock( timeOut );
try
{
// It is safe for this thread to read from
// the shared resource.
Display( String::Format( "reads resource value {0}", resource ) );
Interlocked::Increment( reads );
}
finally
{
// Ensure that the lock is released.
rwl->ReleaseReaderLock();
}
}
catch ( ApplicationException^ )
{
// The reader lock request timed out.
Interlocked::Increment( readerTimeouts );
}
}
// Request and release a reader lock, and handle time-outs.
static void ReadFromResource(int timeOut)
{
try {
rwl.AcquireReaderLock(timeOut);
try {
// It is safe for this thread to read from the shared resource.
Display("reads resource value " + resource);
Interlocked.Increment(ref reads);
}
finally {
// Ensure that the lock is released.
rwl.ReleaseReaderLock();
}
}
catch (ApplicationException) {
// The reader lock request timed out.
Interlocked.Increment(ref readerTimeouts);
}
}
' Request and release a reader lock, and handle time-outs.
Sub ReadFromResource(timeOut As Integer)
Try
rwl.AcquireReaderLock(timeOut)
Try
' It's safe for this thread to read from the shared resource.
Display("reads resource value " & resource)
Interlocked.Increment(reads)
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
Poznámky
AcquireReaderLock blokuje, pokud má jiné vlákno zámek zapisovač nebo pokud alespoň jedno vlákno čeká na zámek zapisovače.
Poznámka
Pokud už má aktuální vlákno zámek zapisovače, není získán žádný zámek čtečky. Místo toho se zvýší počet zámků zapisovačů. Tím zabráníte blokování vlákna na vlastním zapisovacím zámku. Výsledek je přesně stejný jako volání AcquireWriterLocka při uvolnění zámku zapisovači se vyžaduje další volání ReleaseWriterLock .
AcquireReaderLock
podporuje rekurzivní žádosti o uzamčení čtečky. To znamená, že vlákno může volat AcquireReaderLock několikrát, což zvýší počet zámků pokaždé. Pokaždé, když zavoláte, musíte volat ReleaseReaderLock AcquireReaderLock
jednou. Alternativně můžete volat ReleaseLock , abyste snížili počet zámků na nulu okamžitě.
Rekurzivní žádosti o zámek jsou vždy uděleny okamžitě, aniž by bylo nutné umístit vlákno žádosti do fronty čtenáře. Používejte rekurzivní zámky s opatrností, abyste se vyhnuli blokování žádostí o zámek zapisovačů po dlouhou dobu.
Platné hodnoty časového limitu najdete v tématu ReaderWriterLock.
Viz také
Platí pro
AcquireReaderLock(TimeSpan)
Získá zámek čtečky s použitím TimeSpan hodnoty pro časový limit.
public:
void AcquireReaderLock(TimeSpan timeout);
public void AcquireReaderLock (TimeSpan timeout);
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public void AcquireReaderLock (TimeSpan timeout);
member this.AcquireReaderLock : TimeSpan -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("browser")>]
member this.AcquireReaderLock : TimeSpan -> unit
Public Sub AcquireReaderLock (timeout As TimeSpan)
Parametry
- timeout
- TimeSpan
Určení TimeSpan
časového limitu.
- Atributy
Výjimky
timeout
vyprší před udělením žádosti o zámek.
timeout
určuje jinou zápornou hodnotu než -1 milisekund.
Poznámky
AcquireReaderLock blokuje, pokud má jiné vlákno zámek zapisovač nebo pokud alespoň jedno vlákno čeká na zámek zapisovače.
Poznámka
Pokud už má aktuální vlákno zámek zapisovače, není získán žádný zámek čtečky. Místo toho se zvýší počet zámků zapisovačů. Tím zabráníte blokování vlákna na vlastním zapisovacím zámku. Výsledek je přesně stejný jako volání AcquireWriterLocka při uvolnění zámku zapisovači se vyžaduje další volání ReleaseWriterLock .
AcquireReaderLock
podporuje rekurzivní žádosti o uzamčení čtečky. To znamená, že vlákno může volat AcquireReaderLock několikrát, což zvýší počet zámků pokaždé. Pokaždé, když zavoláte, musíte volat ReleaseReaderLock AcquireReaderLock
jednou. Alternativně můžete volat ReleaseLock , abyste snížili počet zámků na nulu okamžitě.
Rekurzivní žádosti o zámek jsou vždy uděleny okamžitě, aniž by bylo nutné umístit vlákno žádosti do fronty čtenáře. Používejte rekurzivní zámky s opatrností, abyste se vyhnuli blokování žádostí o zámek zapisovačů po dlouhou dobu.
Platné hodnoty časového limitu najdete v tématu ReaderWriterLock.