IEquatable<T>.Equals(T) Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Indique si l'objet actuel est égal à un autre objet du même type.
public:
bool Equals(T other);
public bool Equals (T other);
public bool Equals (T? other);
abstract member Equals : 'T -> bool
Public Function Equals (other As T) As Boolean
Paramètres
- other
- T
Objet à comparer à cet objet.
Retours
true
si l'objet actuel est égal au paramètre other
; sinon, false
.
Exemples
L’exemple suivant montre l’implémentation partielle d’une Person
classe qui implémente IEquatable<T> et a deux propriétés, LastName
et SSN
. La Equals méthode retourne True
si la SSN
propriété de deux Person
objets est identique ; sinon, elle retourne False
.
using System;
using System.Collections.Generic;
using System.Text.RegularExpressions;
public class Person : IEquatable<Person>
{
private string uniqueSsn;
private string lName;
public Person(string lastName, string ssn)
{
if (Regex.IsMatch(ssn, @"\d{9}"))
uniqueSsn = $"{ssn.Substring(0, 3)}-{ssn.Substring(3, 2)}-{ssn.Substring(5, 4)}";
else if (Regex.IsMatch(ssn, @"\d{3}-\d{2}-\d{4}"))
uniqueSsn = ssn;
else
throw new FormatException("The social security number has an invalid format.");
this.LastName = lastName;
}
public string SSN
{
get { return this.uniqueSsn; }
}
public string LastName
{
get { return this.lName; }
set {
if (String.IsNullOrEmpty(value))
throw new ArgumentException("The last name cannot be null or empty.");
else
this.lName = value;
}
}
public bool Equals(Person other)
{
if (other == null)
return false;
if (this.uniqueSsn == other.uniqueSsn)
return true;
else
return false;
}
public override bool Equals(Object obj)
{
if (obj == null)
return false;
Person personObj = obj as Person;
if (personObj == null)
return false;
else
return Equals(personObj);
}
public override int GetHashCode()
{
return this.SSN.GetHashCode();
}
public static bool operator == (Person person1, Person person2)
{
if (((object)person1) == null || ((object)person2) == null)
return Object.Equals(person1, person2);
return person1.Equals(person2);
}
public static bool operator != (Person person1, Person person2)
{
if (((object)person1) == null || ((object)person2) == null)
return ! Object.Equals(person1, person2);
return ! (person1.Equals(person2));
}
}
open System
open System.Text.RegularExpressions
type Person(lastName, ssn) =
let mutable lastName = lastName
let ssn =
if Regex.IsMatch(ssn, @"\d{9}") then
$"{ssn.Substring(0, 3)}-{ssn.Substring(3, 2)}-{ssn.Substring(5, 4)}"
elif Regex.IsMatch(ssn, @"\d{3}-\d{2}-\d{4}") then
ssn
else
raise (FormatException "The social security number has an invalid format.")
member _.SSN =
ssn
member _.LastName
with get () = lastName
and set (value) =
if String.IsNullOrEmpty value then
invalidArg (nameof value) "The last name cannot be null or empty."
else
lastName <- value
static member op_Equality (person1: Person, person2: Person) =
if box person1 |> isNull || box person2 |> isNull then
Object.Equals(person1, person2)
else
person1.Equals person2
static member op_Inequality (person1: Person, person2: Person) =
if box person1 |> isNull || box person2 |> isNull then
Object.Equals(person1, person2) |> not
else
person1.Equals person2 |> not
override _.GetHashCode() =
ssn.GetHashCode()
override this.Equals(obj: obj) =
match obj with
| :? Person as personObj ->
(this :> IEquatable<_>).Equals personObj
| _ -> false
interface IEquatable<Person> with
member this.Equals(other: Person) =
match box other with
| null -> false
| _ ->
this.SSN = other.SSN
Imports System.Collections.Generic
Imports System.Text.RegularExpressions
Public Class Person : Implements IEquatable(Of Person)
Private uniqueSsn As String
Private lName As String
Public Sub New(lastName As String, ssn As String)
If Regex.IsMatch(ssn, "\d{9}") Then
uniqueSsn = $"{ssn.Substring(0, 3)}-{ssn.Substring(3, 2)}-{ssn.Substring(5, 4)}"
ElseIf Regex.IsMatch(ssn, "\d{3}-\d{2}-\d{4}") Then
uniqueSsn = ssn
Else
Throw New FormatException("The social security number has an invalid format.")
End If
Me.LastName = lastName
End Sub
Public ReadOnly Property SSN As String
Get
Return Me.uniqueSsn
End Get
End Property
Public Property LastName As String
Get
Return Me.lName
End Get
Set
If String.IsNullOrEmpty(value) Then
Throw New ArgumentException("The last name cannot be null or empty.")
Else
lname = value
End If
End Set
End Property
Public Overloads Function Equals(other As Person) As Boolean _
Implements IEquatable(Of Person).Equals
If other Is Nothing Then Return False
If Me.uniqueSsn = other.uniqueSsn Then
Return True
Else
Return False
End If
End Function
Public Overrides Function Equals(obj As Object) As Boolean
If obj Is Nothing Then Return False
Dim personObj As Person = TryCast(obj, Person)
If personObj Is Nothing Then
Return False
Else
Return Equals(personObj)
End If
End Function
Public Overrides Function GetHashCode() As Integer
Return Me.SSN.GetHashCode()
End Function
Public Shared Operator = (person1 As Person, person2 As Person) As Boolean
If person1 Is Nothing OrElse person2 Is Nothing Then
Return Object.Equals(person1, person2)
End If
Return person1.Equals(person2)
End Operator
Public Shared Operator <> (person1 As Person, person2 As Person) As Boolean
If person1 Is Nothing OrElse person2 Is Nothing Then
Return Not Object.Equals(person1, person2)
End If
Return Not person1.Equals(person2)
End Operator
End Class
Person
Les objets peuvent ensuite être stockés dans un List<T> objet et peuvent être identifiés par la Contains
méthode , comme le montre l’exemple suivant.
public class TestIEquatable
{
public static void Main()
{
// Create a Person object for each job applicant.
Person applicant1 = new Person("Jones", "099-29-4999");
Person applicant2 = new Person("Jones", "199-29-3999");
Person applicant3 = new Person("Jones", "299-49-6999");
// Add applicants to a List object.
List<Person> applicants = new List<Person>();
applicants.Add(applicant1);
applicants.Add(applicant2);
applicants.Add(applicant3);
// Create a Person object for the final candidate.
Person candidate = new Person("Jones", "199-29-3999");
if (applicants.Contains(candidate))
Console.WriteLine("Found {0} (SSN {1}).",
candidate.LastName, candidate.SSN);
else
Console.WriteLine("Applicant {0} not found.", candidate.SSN);
// Call the shared inherited Equals(Object, Object) method.
// It will in turn call the IEquatable(Of T).Equals implementation.
Console.WriteLine("{0}({1}) already on file: {2}.",
applicant2.LastName,
applicant2.SSN,
Person.Equals(applicant2, candidate));
}
}
// The example displays the following output:
// Found Jones (SSN 199-29-3999).
// Jones(199-29-3999) already on file: True.
// Create a Person object for each job applicant.
let applicant1 = Person("Jones", "099-29-4999")
let applicant2 = Person("Jones", "199-29-3999")
let applicant3 = Person("Jones", "299-49-6999")
// Add applicants to a List object.
let applicants = ResizeArray()
applicants.Add applicant1
applicants.Add applicant2
applicants.Add applicant3
// Create a Person object for the final candidate.
let candidate = Person("Jones", "199-29-3999")
if applicants.Contains candidate then
printfn $"Found {candidate.LastName} (SSN {candidate.SSN})."
else
printfn $"Applicant {candidate.SSN} not found."
// Call the shared inherited Equals(Object, Object) method.
// It will in turn call the IEquatable<T>.Equals implementation.
printfn $"{applicant2.LastName}({applicant2.SSN}) already on file: {Person.Equals(applicant2, candidate)}."
// The example displays the following output:
// Found Jones (SSN 199-29-3999).
// Jones(199-29-3999) already on file: True.
Module TestIEquatable
Public Sub Main()
' Create a Person object for each job applicant.
Dim applicant1 As New Person("Jones", "099-29-4999")
Dim applicant2 As New Person("Jones", "199-29-3999")
Dim applicant3 As New Person("Jones", "299-49-6999")
' Add applicants to a List object.
Dim applicants As New List(Of Person)
applicants.Add(applicant1)
applicants.Add(applicant2)
applicants.Add(applicant3)
' Create a Person object for the final candidate.
Dim candidate As New Person("Jones", "199-29-3999")
If applicants.Contains(candidate) Then
Console.WriteLine("Found {0} (SSN {1}).", _
candidate.LastName, candidate.SSN)
Else
Console.WriteLine("Applicant {0} not found.", candidate.SSN)
End If
' Call the shared inherited Equals(Object, Object) method.
' It will in turn call the IEquatable(Of T).Equals implementation.
Console.WriteLine("{0}({1}) already on file: {2}.", _
applicant2.LastName, _
applicant2.SSN, _
Person.Equals(applicant2, candidate))
End Sub
End Module
' The example displays the following output:
' Found Jones (SSN 199-29-3999).
' Jones(199-29-3999) already on file: True.
Remarques
L’implémentation de la Equals méthode est destinée à effectuer un test d’égalité avec un autre objet de type T
, le même type que l’objet actuel. La Equals(T) méthode est appelée dans les circonstances suivantes :
Lorsque la
Equals
méthode est appelée et que l’argumentother
est un objet fortement typé de typeT
. (Siother
n’est pas de typeT
, la méthode de base Object.Equals(Object) est appelée. Des deux méthodes, IEquatable<T>.Equals offre des performances légèrement meilleures.)Lorsque les méthodes de recherche d’un certain nombre d’objets de collection génériques sont appelées. Certains de ces types et leurs méthodes incluent les éléments suivants :
Certaines des surcharges génériques de la BinarySearch méthode .
Méthodes de recherche de la List<T> classe, notamment List<T>.Contains(T), List<T>.IndexOf, List<T>.LastIndexOfet List<T>.Remove.
Méthodes de recherche de la Dictionary<TKey,TValue> classe, y compris ContainsKey et Remove.
Méthodes de recherche de la classe générique LinkedList<T> , notamment LinkedList<T>.Contains et Remove.
En d’autres termes, pour gérer la possibilité que des objets d’une classe soient stockés dans un tableau ou un objet de collection générique, il est judicieux d’implémenter IEquatable<T> afin que l’objet puisse être facilement identifié et manipulé.
Lors de l’implémentation de la Equals méthode, définissez l’égalité de manière appropriée pour le type spécifié par l’argument de type générique. Par exemple, si l’argument type est Int32, définissez l’égalité de manière appropriée pour la comparaison de deux entiers signés 32 bits.
Notes pour les responsables de l’implémentation
Si vous implémentez Equals(T), vous devez également remplacer les implémentations de classe de base de Equals(Object) et GetHashCode() afin que leur comportement soit cohérent avec celui de la Equals(T) méthode . Si vous remplacez Equals(Object), votre implémentation remplacée est également appelée dans les appels à la méthode statique Equals(System.Object, System.Object)
sur votre classe. En outre, vous devez surcharger les op_Equality
opérateurs et .op_Inequality
Cela garantit que tous les tests d’égalité retournent des résultats cohérents, ce que l’exemple illustre.