ReaderWriterLock.DowngradeFromWriterLock(LockCookie) メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
スレッドのロック ステータスを、UpgradeToWriterLock(Int32) を呼び出す前の状態に復元します。
public:
void DowngradeFromWriterLock(System::Threading::LockCookie % lockCookie);
public void DowngradeFromWriterLock(ref System.Threading.LockCookie lockCookie);
member this.DowngradeFromWriterLock : LockCookie -> unit
Public Sub DowngradeFromWriterLock (ByRef lockCookie As LockCookie)
パラメーター
- lockCookie
- LockCookie
LockCookie によって戻される UpgradeToWriterLock(Int32)。
例外
スレッドがライター ロックを保持していません。
lockCookie
のアドレスは null ポインターです。
例
次のコード例は、リーダー ロックを要求し、リーダー ロックをライター ロックにアップグレードし、リーダー ロックに再度ダウングレードする方法を示しています。
このコードは、 クラスに対して提供されるより大きな例の ReaderWriterLock 一部です。
// 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
// Requests a reader lock, upgrades the reader lock to the writer
// lock, and downgrades it to a reader lock again.
static void UpgradeDowngrade(Random rnd, int timeOut)
{
try {
rwl.AcquireReaderLock(timeOut);
try {
// It's safe for this thread to read from the shared resource.
Display("reads resource value " + resource);
Interlocked.Increment(ref reads);
// To write to the resource, either release the reader lock and
// request the writer lock, or upgrade the reader lock. Upgrading
// the reader lock puts the thread in the write queue, behind any
// other threads that might be waiting for the writer lock.
try {
LockCookie lc = rwl.UpgradeToWriterLock(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(ref writes);
}
finally {
// Ensure that the lock is released.
rwl.DowngradeFromWriterLock(ref lc);
}
}
catch (ApplicationException) {
// The upgrade request timed out.
Interlocked.Increment(ref writerTimeouts);
}
// If the lock was downgraded, it's still safe to read from the 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);
}
}
' Requests a reader lock, upgrades the reader lock to the writer
' lock, and downgrades it to a reader lock again.
Sub UpgradeDowngrade(rnd As Random, 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)
' To write to the resource, either release the reader lock and
' request the writer lock, or upgrade the reader lock. Upgrading
' the reader lock puts the thread in the write queue, behind any
' other threads that might be waiting for the writer lock.
Try
Dim lc As LockCookie = rwl.UpgradeToWriterLock(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.DowngradeFromWriterLock(lc)
End Try
Catch ex As ApplicationException
' The upgrade request timed out.
Interlocked.Increment(writerTimeouts)
End Try
' If the lock was downgraded, it's still safe to read from the 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
注釈
DowngradeFromWriterLock は再帰的ロック数に関係なくライター ロックを解放し、ライター ロックにアップグレードする前にスレッドによって保持されていたリーダー ロックを復元します。 リーダー ロックのロック数が復元されます。
Note
DowngradeFromWriterLock
は を呼び出UpgradeToWriterLockして取得した をLockCookie受け入れます。 によってReleaseLock返される をLockCookie
使用しないでください。
ライター ロックが解放されるとすべてのリーダー ロック要求が許可されるため、他のスレッドがライター ロックを待機している場合でも、ライター ロックからダウングレードしても、スレッドはブロックされません。