CA2002:不要锁定具有弱标识的对象

属性
规则 ID CA2002
标题 不要锁定具有弱标识的对象
类别 可靠性
修复是中断修复还是非中断修复 非中断
在 .NET 8 中默认启用

原因

线程尝试在具有弱标识的对象上获取锁。

规则说明

当可以跨应用程序域边界直接进行访问对象时,则认为该对象具有弱标识。 对于尝试获取对具有弱标识的对象的锁的线程,该线程可能会被其他应用程序域中持有对同一对象的锁的另一线程所阻止。

以下类型具有弱标识,并由规则标记:

如何解决冲突

若要解决与此规则的冲突,请使用“描述”部分中未包含的类型的对象。

何时禁止显示警告

如果锁定的对象为 thisMe,且 self 对象类型的可见性为专用或内部,并且不能使用任何公共引用访问该实例,可禁止显示该警告。

否则,请勿禁止显示此规则的警告。

抑制警告

如果只想抑制单个冲突,请将预处理器指令添加到源文件以禁用该规则,然后重新启用该规则。

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

若要对文件、文件夹或项目禁用该规则,请在配置文件中将其严重性设置为 none

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

有关详细信息,请参阅如何禁止显示代码分析警告

CA2213:应释放可释放的字段

示例

以下示例显示了一些与规则冲突的对象锁。

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 MemoryStream();
        lock (stream) { }
    }

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

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

另请参阅