CA2013: Não use ReferenceEquals com tipos de valor
Property | valor |
---|---|
ID da regra | CA2013 |
Título | Não use ReferenceEquals com tipos de valor |
Categoria | Fiabilidade |
A correção está quebrando ou não quebrando | Sem quebra |
Habilitado por padrão no .NET 9 | Como aviso |
Motivo
Usando System.Object.ReferenceEquals o método para testar um ou mais tipos de valor para igualdade.
Descrição da regra
Ao comparar valores usando ReferenceEquals, se objA e objB são tipos de valor, eles são encaixotados antes de serem passados para o ReferenceEquals método. Isso significa que, mesmo que objA e objB representem a mesma instância de um tipo de valor, o ReferenceEquals método retorna false, como mostra o exemplo a seguir.
Como corrigir violações
Para corrigir a violação, substitua-a por uma verificação de igualdade mais apropriada, como ==
.
int int1 = 1, int2 = 1;
// Violation occurs, returns false.
Console.WriteLine(Object.ReferenceEquals(int1, int2)); // false
// Use appropriate equality operator or method instead
Console.WriteLine(int1 == int2); // true
Console.WriteLine(object.Equals(int1, int2)); // true
Quando suprimir avisos
Não é seguro suprimir uma advertência desta regra. Recomendamos o uso do operador de igualdade mais apropriado, como ==
.