CA2002: Zayıf kimliği olan nesneleri kilitlemeyin

Özellik Değer
Kural Kimliği CA2002
Başlık Zayıf kimliği olan nesneleri kilitlemeyin
Kategori Güvenilirlik
Düzeltme bozucu ya da bozmayan olabilir Kesintisiz
.NET 10'da varsayılan olarak etkin Hayır
Geçerli diller C# ve Visual Basic

Neden

İş parçacığı, zayıf bir kimliğe sahip bir nesneyi kilitlemeye çalışır.

Kural açıklaması

Bir nesneye uygulama etki alanları arasından erişilebiliyorsa o nesnenin zayıf bir kimliğe sahip olduğu söylenir. Zayıf kimliğe sahip bir nesne üzerinde kilit almayı deneyen iş parçacığı aynı nesne üzerinde bir kilide sahip olan farklı uygulama etki alanı içindeki ikinci iş parçacığı tarafından engellenebilir.

Aşağıdaki türler zayıf bir kimliğe sahiptir ve kural tarafından bayrakla işaretlenir:

İhlalleri düzeltme

Bu kuralın ihlalini düzeltmek için, Açıklama bölümündeki listede bulunmayan bir türdeki bir nesneyi kullanın.

Uyarıların ne zaman bastırılması gerekiyor?

Kilitli nesne this veya Me olduğunda ve kendi nesne türünün görünürlüğü özel veya dahili ise ve örneğe herhangi bir genel referans kullanılarak erişilemiyorsa uyarıyı gizlemek güvenlidir.

Aksi takdirde, bu kurala ait bir uyarıyı gizlemeyin.

Uyarıyı gizleme

Yalnızca tek bir ihlali engellemek istiyorsanız, kuralı devre dışı bırakmak ve sonra yeniden etkinleştirmek için kaynak dosyanıza ön işlemci yönergeleri ekleyin.

#pragma warning disable CA2002
// The code that's violating the rule is on this line.
#pragma warning restore CA2002

Bir dosya, klasör veya projenin kuralını devre dışı bırakmak için, yapılandırma dosyasındaki önem derecesini noneolarak ayarlayın.

[*.{cs,vb}]
dotnet_diagnostic.CA2002.severity = none

Daha fazla bilgi için bkz . Kod analizi uyarılarını gizleme.

CA2213: Imha edilebilir alanlar imha edilmelidir

Örnek

Aşağıdaki örnekte kuralı ihlal eden bazı nesne kilitleri gösterilmektedir.

Imports System
Imports System.IO
Imports System.Reflection
Imports System.Threading

Namespace ca2002

    Class WeakIdentities

        Sub SyncLockOnWeakId1()

            SyncLock GetType(WeakIdentities)
            End SyncLock

        End Sub

        Sub SyncLockOnWeakId2()

            Dim stream As New MemoryStream()
            SyncLock stream
            End SyncLock

        End Sub

        Sub SyncLockOnWeakId3()

            SyncLock "string"
            End SyncLock

        End Sub

        Sub SyncLockOnWeakId4()

            Dim member As MemberInfo =
            Me.GetType().GetMember("SyncLockOnWeakId1")(0)
            SyncLock member
            End SyncLock

        End Sub

        Sub SyncLockOnWeakId5()

            Dim outOfMemory As New OutOfMemoryException()
            SyncLock outOfMemory
            End SyncLock

        End Sub

    End Class

End Namespace
class WeakIdentities
{
    void LockOnWeakId1()
    {
        lock (typeof(WeakIdentities)) { }
    }

    void LockOnWeakId2()
    {
        MemoryStream stream = new();
        lock (stream) { }
    }

    void LockOnWeakId3()
    {
        lock ("string") { }
    }

    void LockOnWeakId4()
    {
        MemberInfo member = this.GetType().GetMember("LockOnWeakId1")[0];
        lock (member) { }
    }
    void LockOnWeakId5()
    {
        OutOfMemoryException outOfMemory = new();
        lock (outOfMemory) { }
    }
}

Ayrıca bkz.