Share via


CA1864: 'IDictionary.TryAdd(TKey, TValue)' 메서드를 선호합니다.

속성
규칙 ID CA1864
타이틀 'IDictionary.TryAdd(TKey, TValue)' 메서드를 선호합니다.
범주 성능
수정 사항이 주요 변경인지 여부 주요 변경 아님
.NET 8에서 기본적으로 사용 제안 사항

원인

Dictionary<TKey,TValue>.Add 는 호출에 Dictionary<TKey,TValue>.ContainsKey(TKey) 의해 보호됩니다.

규칙 설명

Dictionary<TKey,TValue>.Add 둘 다 Dictionary<TKey,TValue>.ContainsKey(TKey) 중복되는 조회를 수행합니다. Dictionary<TKey,TValue>.Add 또한 키가 사전에 이미 있는 경우 예외를 throw합니다. 값이 추가되었는지 여부를 나타내는 부울 값을 반환하는 호출 Dictionary<TKey,TValue>.TryAdd이 더 효율적입니다. TryAdd 는 키가 이미 있는 경우 키의 값을 덮어쓰지 않습니다.

위반 문제를 해결하는 방법

호출 Dictionary<TKey,TValue>.ContainsKey(TKey) 다음에 호출을 한 번의 호출 Dictionary<TKey,TValue>.Add 로 대체합니다 Dictionary<TKey,TValue>.TryAdd.

예시

다음 코드 조각은 CA1864 위반을 보여줍니다.

void Run(IDictionary<int, string> dictionary)
{
    if(!dictionary.ContainsKey(2)) {
        dictionary.Add(2, "Hello World");
    }
}
Sub Run(dictionary As IDictionary(Of Integer, String))
    If Not dictionary.ContainsKey(2) Then
        dictionary.Add(2, "Hello World")
    End If
End Sub

다음 코드 조각은 이 위반을 해결합니다.

void Run(IDictionary<int, string> dictionary)
{
    dictionary.TryAdd(2, "Hello World");
}
Sub Run(dictionary As IDictionary(Of Integer, String))
    dictionary.TryAdd(2, "Hello World")
End Sub

경고를 표시하지 않는 경우

성능이 문제가 되지 않고 throw Dictionary<TKey,TValue>.Add될 수 있는 예외를 처리하는 경우 이 경고를 표시하지 않아도 됩니다.

경고 표시 안 함

단일 위반만 표시하지 않으려면 원본 파일에 전처리기 지시문을 추가하여 규칙을 사용하지 않도록 설정한 후 다시 사용하도록 설정합니다.

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

파일, 폴더 또는 프로젝트에 대한 규칙을 사용하지 않도록 설정하려면 구성 파일에서 심각도를 none으로 설정합니다.

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

자세한 내용은 방법: 코드 분석 경고 표시 안 함을 참조하세요.