CA1066: Eşittir'i geçersiz kılırken IEquatable uygulama
Özellik | Değer |
---|---|
Kural Kimliği | CA1066 |
Başlık | Equals’ı geçersiz kılarken IEquatable uygulayın |
Kategori | Tasarım |
Hataya neden olan veya bozulmayan düzeltme | Hataya neden olmayan |
.NET 9'da varsayılan olarak etkin | Hayır |
Neden
Bir değer türü (yapı) yöntemini geçersiz kılar Equals , ancak uygulamaz IEquatable<T>.
Kural açıklaması
Geçersiz kılma Equals yöntemi, değer eşitliği için türün iki örneğini karşılaştırmayı desteklediğini gösterir. Eşitlik için kesin olarak belirlenmiş testleri desteklemek için arabirimini uygulamayı IEquatable<T> göz önünde bulundurun. Bu, eşitlik denetimleri gerçekleştiren çağıranların kesin olarak yazılan System.IEquatable<T>.Equals yöntemi çağırmasını ve bağımsız değişkeni kutulamaktan kaçınarak performansı geliştirmesini sağlar. Daha fazla bilgi için buraya bakın.
Uygulamanız System.IEquatable<T>.Equals ile Equalstutarlı sonuçlar döndürmelidir.
İhlalleri düzeltme
Bir ihlali düzeltmek için bu uygulanan yöntemi çağırmak için geçersiz kılmayı uygulayın IEquatable<T> ve güncelleştirin Equals . Örneğin, aşağıdaki iki kod parçacığı kuralın ihlalini ve nasıl düzeltileceğini gösterir:
public struct S
{
private readonly int _value;
public S(int f)
{
_value = f;
}
public override int GetHashCode()
=> _value.GetHashCode();
public override bool Equals(object other)
=> other is S otherS && _value == otherS._value;
}
using System;
public struct S : IEquatable<S>
{
private readonly int _value;
public S(int f)
{
_value = f;
}
public override int GetHashCode()
=> _value.GetHashCode();
public override bool Equals(object other)
=> other is S otherS && Equals(otherS);
public bool Equals(S other)
=> _value == other._value;
}
Uyarıların ne zaman bastırılması gerekiyor?
Arabirimin uygulanmasından elde edilir tasarım ve performans avantajları kritik değilse, bu kuraldaki ihlalleri engellemek güvenlidir.
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 CA1066
// The code that's violating the rule is on this line.
#pragma warning restore CA1066
Bir dosya, klasör veya projenin kuralını devre dışı bırakmak için, yapılandırma dosyasındaki önem derecesini none
olarak ayarlayın.
[*.{cs,vb}]
dotnet_diagnostic.CA1066.severity = none
Daha fazla bilgi için bkz . Kod analizi uyarılarını gizleme.