약한 ID를 가진 개체를 잠그지 마십시오.
업데이트: 2007년 11월
TypeName |
DoNotLockOnObjectsWithWeakIdentity |
CheckId |
CA2002 |
범주 |
Microsoft.Reliability |
변경 수준 |
주요 변경 아님 |
원인
스레드에서 약한 ID를 가진 개체에 대해 잠금을 가져오려고 합니다.
규칙 설명
응용 프로그램 도메인 경계를 가로질러 직접 액세스할 수 있는 개체를 약한 ID를 가진 개체라고 합니다. 약한 ID를 가진 개체에 대해 잠금을 가져오려고 시도하는 스레드는 같은 개체에 대해 잠금을 가진 다른 응용 프로그램 도메인의 스레드에 의해 차단될 수 있습니다. 다음 형식은 약한 ID를 가지며 규칙에 의해 플래그가 지정됩니다.
위반 문제를 해결하는 방법
이 규칙 위반 문제를 해결하려면 설명 섹션의 목록에 나와 있지 않은 형식의 개체를 사용합니다.
경고를 표시하지 않는 경우
이 규칙에서는 경고를 표시해야 합니다.
예제
다음 예제에서는 이 규칙을 위반하는 몇 개의 개체 잠금을 보여 줍니다.
Imports System
Imports System.IO
Imports System.Reflection
Imports System.Threading
Namespace ReliabilityLibrary
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
using System;
using System.IO;
using System.Reflection;
using System.Threading;
namespace ReliabilityLibrary
{
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) {}
}
}
}