IEquatable<T> Arabirim
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Bir değer türünün veya sınıfın örneklerin eşitliğini belirlemek için türe özgü bir yöntem oluşturmak için uyguladığı genelleştirilmiş bir yöntemi tanımlar.
generic <typename T>
public interface class IEquatable
public interface IEquatable<T>
type IEquatable<'T> = interface
Public Interface IEquatable(Of T)
- T
Karşılaştıracak nesne türü.
- Türetilmiş
IEquatable<T>.Equals yöntemi örneğine bakın.
Bu arabirim, değerleri eşitlenebilen türler tarafından uygulanır (örneğin, sayısal ve dize sınıfları). Değer türü veya sınıfı, örneklerin eşitliğini belirlemeye uygun türe özgü bir yöntem oluşturmak için Equals yöntemini uygular.
Not
IComparable<T> arabirimi, uygulama türünün örneklerinin sıralama düzenini belirleyen CompareTo yöntemini tanımlar. IEquatable<T> arabirimi, uygulama türünün örneklerinin eşitliğini belirleyen Equals yöntemini tanımlar.
IEquatable<T> arabirimi, Dictionary<TKey,TValue>, List<T>ve LinkedList<T> gibi genel koleksiyon nesneleri tarafından Contains
, IndexOf
, LastIndexOf
ve Remove
gibi yöntemlerde eşitlik testi yaparken kullanılır. Genel bir koleksiyonda depolanabilecek herhangi bir nesne için uygulanmalıdır.
IEquatable<T> arabiriminin type parametresini bu arabirimi uygulayan türle değiştirin.
IEquatable<T>uygularsanız, davranışları Equals(T) yöntemiyle tutarlı olması için Equals(Object) ve GetHashCode() temel sınıf uygulamalarını da geçersiz kılmalısınız.
Equals(Object)geçersiz kılarsanız geçersiz kılınan uygulamanız, sınıfınızdaki statik Equals(System.Object, System.Object)
yöntemine yapılan çağrılarda da çağrılır. Ayrıca, op_Equality
ve op_Inequality
işleçlerini aşırı yüklemelisiniz. Bu, eşitlik için tüm testlerin tutarlı sonuçlar döndürmesini sağlar.
Equals(Object)geçersiz kılma hakkında bilgi için bkz. Equals(Object).
Bir değer türü için her zaman daha iyi performans için IEquatable<T> uygulamalı ve Equals(Object) geçersiz kılmalısınız. Equals(Object) kutuları değer türleridir ve eşitlik için iki değeri karşılaştırmak için yansımaya dayanır. Hem Equals(T) uygulamanız hem de Equals(Object) geçersiz kılmanız tutarlı sonuçlar döndürmelidir.
IEquatable<T>uygularsanız, türünüzün örnekleri sıralanabilir veya sıralanabilirse IComparable<T> de uygulamanız gerekir. Türünüz IComparable<T>uygularsa, neredeyse her zaman IEquatable<T>uygularsınız.
Bir türün sipariş ilişkisini desteklediği ancak eşitliğin bir sipariş ilişkisinden farklı olabileceği bazı tasarımlar olduğunu unutmayın. Alfabetik olarak sıraladığınız bir Person
sınıfı düşünün. Aynı ada sahip iki kişi aynı şekilde sıralanır ancak aynı kişi değildir.
Equals(T) |
Geçerli nesnenin aynı türdeki başka bir nesneye eşit olup olmadığını gösterir. |
Ürün | Sürümler |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1 |
UWP | 10.0 |
.NET geri bildirimi
.NET, açık kaynak bir projedir. Geri bildirim sağlamak için bir bağlantı seçin: