İngilizce dilinde oku

Aracılığıyla paylaş


LockRecursionException Sınıf

Tanım

Bir kilide özyinelemeli giriş olduğunda oluşan özel durum, kilidin özyineleme ilkesiyle uyumlu değildir.

C#
public class LockRecursionException : Exception
C#
[System.Serializable]
public class LockRecursionException : Exception
Devralma
LockRecursionException
Öznitelikler

Örnekler

Aşağıdaki örnekte, sınıfını kullanmanın iki nedeni LockRecursionException gösterilmektedir ReaderWriterLockSlim . Program, özyineleme izin veren parametresiz oluşturucuyu kullanarak bir ReaderWriterLockSlim oluşturur. Ardından program, kilit okuma moduna giren bir iş parçacığı başlatır. İş parçacığı, kilidi yinelemeli olarak okuma moduna girmeye çalışır ve sonuçta elde edilen özel durumu yakalar. Son olarak, iş parçacığı yazma moduna girmeye çalışır ve bu da kilitlenme olasılığına neden olur. İş parçacığı, sonuçta elde edilen özel durumu yakalar.

C#
using System;
using System.Threading;

class Example
{
    // By default, the lock recursion policy for a new 
    // ReaderWriterLockSlim does not allow recursion.
    static ReaderWriterLockSlim rwls = new ReaderWriterLockSlim();

    static void ThreadProc()
    {
        Console.WriteLine("Acquire the reader lock.");
        rwls.EnterReadLock();

        try
        {
            Console.WriteLine("\nAttempt to acquire the reader lock recursively:");
            rwls.EnterReadLock();
        }
        catch (LockRecursionException lre)
        {
            Console.WriteLine("{0}: {1}", 
                lre.GetType().Name, lre.Message);
        }

        try
        {
            Console.WriteLine("\nAttempt to acquire the writer lock recursively:");
            rwls.EnterWriteLock();
        }
        catch (LockRecursionException lre)
        {
            Console.WriteLine("{0}: {1}", 
                lre.GetType().Name, lre.Message);
        }
    }

    static void Main()
    {
        Thread t = new Thread(ThreadProc);
        t.Start();
        t.Join();
    }
}

/* This code example produces output similar to the following:

Acquire the reader lock.

Attempt to acquire the reader lock recursively:
LockRecursionException: Recursive read lock acquisitions not allowed in this mode.

Attempt to acquire the writer lock recursively:
LockRecursionException: Write lock may not be acquired with read lock held. This pattern is prone to deadlocks. Consider using the upgrade lock.
 */

Açıklamalar

LockRecursionException aşağıdakiler de dahil olmak üzere çeşitli nedenlerle oluşturulur:

  • bir iş parçacığı yinelemeli olarak bir örneğini ReaderWriterLockSlim girmeye çalışırsa, ancak örnek özyinelemesi desteklemiyorsa.

  • bir iş parçacığı yazma modunda veya yükseltilebilir modda bir ReaderWriterLockSlim örneği girmeye çalışırsa, iş parçacığı ilk olarak okuma modunda kilide girdi. Bu, olası bir kilitlenmeyi temsil eder ve bu nedenle izin verilmez.

  • Bir özyineleme düzeyi daha izin verirseniz, özyinelemeleri izlemek için kullanılan iç depolama sayacı için maksimum değeri aşabilir. Bu sınır, uygulamaların hiçbir zaman karşılaşmaması gereken kadar büyük.

Oluşturucular

LockRecursionException()

Hatanın LockRecursionException açıklandığı sistem tarafından sağlanan bir iletiyle sınıfının yeni bir örneğini başlatır.

LockRecursionException(SerializationInfo, StreamingContext)

LockRecursionException sınıfının yeni bir örneğini serileştirilmiş verilerle başlatır.

LockRecursionException(String)

Hatanın LockRecursionException açıklandığı belirtilen iletiyle sınıfının yeni bir örneğini başlatır.

LockRecursionException(String, Exception)

Belirtilen bir hata iletisi ve bu özel durumun nedeni olan iç özel duruma başvuru ile sınıfının yeni bir örneğini LockRecursionException başlatır.

Özellikler

Data

Özel durum hakkında kullanıcı tanımlı ek bilgiler sağlayan bir anahtar/değer çifti koleksiyonu alır.

(Devralındığı yer: Exception)
HelpLink

Bu özel durumla ilişkili yardım dosyasının bağlantısını alır veya ayarlar.

(Devralındığı yer: Exception)
HResult

Belirli bir özel duruma atanan kodlanmış sayısal bir değer olan HRESULT değerini alır veya ayarlar.

(Devralındığı yer: Exception)
InnerException

Exception Geçerli özel duruma neden olan örneği alır.

(Devralındığı yer: Exception)
Message

Geçerli özel durumu açıklayan bir ileti alır.

(Devralındığı yer: Exception)
Source

Hataya neden olan uygulamanın veya nesnenin adını alır veya ayarlar.

(Devralındığı yer: Exception)
StackTrace

Çağrı yığınındaki anlık çerçevelerin dize gösterimini alır.

(Devralındığı yer: Exception)
TargetSite

Geçerli özel durumu oluşturan yöntemini alır.

(Devralındığı yer: Exception)

Yöntemler

Equals(Object)

Belirtilen nesnenin geçerli nesneye eşit olup olmadığını belirler.

(Devralındığı yer: Object)
GetBaseException()

Türetilmiş bir sınıfta geçersiz kılındığında, sonraki bir veya daha fazla özel durumun kök nedeni olan değerini döndürür Exception .

(Devralındığı yer: Exception)
GetHashCode()

Varsayılan karma işlevi işlevi görür.

(Devralındığı yer: Object)
GetObjectData(SerializationInfo, StreamingContext)

Türetilmiş bir sınıfta geçersiz kılındığında, özel durum hakkındaki bilgilerle öğesini ayarlar SerializationInfo .

(Devralındığı yer: Exception)
GetType()

Geçerli örneğin çalışma zamanı türünü alır.

(Devralındığı yer: Exception)
MemberwiseClone()

Geçerli Objectöğesinin sığ bir kopyasını oluşturur.

(Devralındığı yer: Object)
ToString()

Geçerli özel durumun dize gösterimini oluşturur ve döndürür.

(Devralındığı yer: Exception)

Ekinlikler

SerializeObjectState
Kullanımdan kalktı.

Bir özel durum, özel durum hakkında serileştirilmiş veriler içeren bir özel durum nesnesi oluşturmak üzere seri hale getirildiğinde gerçekleşir.

(Devralındığı yer: Exception)

Şunlara uygulanır

Ürün Sürümler
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Ayrıca bkz.