IEquatable<T>.Equals(T) Metodo
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Indica se l'oggetto corrente è uguale a un altro oggetto dello stesso tipo.
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
Parametri
- other
- T
Oggetto da confrontare con l'oggetto corrente.
Restituisce
true
se l'oggetto corrente è uguale al parametro other
; in caso contrario, false
.
Esempio
Nell'esempio seguente viene illustrata l'implementazione parziale di una Person
classe che implementa IEquatable<T> e ha due proprietà e LastName
SSN
. Il Equals metodo restituisce True
se la SSN
proprietà di due Person
oggetti è identica; in caso contrario, restituisce 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
Gli oggetti possono quindi essere archiviati in un List<T> oggetto e possono essere identificati dal Contains
metodo , come illustrato nell'esempio seguente.
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.
Commenti
L'implementazione del Equals metodo è progettata per eseguire un test per verificarne l'uguaglianza con un altro oggetto di tipo T
, lo stesso tipo dell'oggetto corrente. Il Equals(T) metodo viene chiamato nelle circostanze seguenti:
Quando il
Equals
metodo viene chiamato e l'argomentoother
è un oggetto fortemente tipizzato di tipoT
. Seother
non è di tipoT
, viene chiamato il metodo di base Object.Equals(Object) . Dei due metodi, IEquatable<T>.Equals offre prestazioni leggermente migliori.Quando vengono chiamati i metodi di ricerca di un numero di oggetti di raccolta generici. Alcuni di questi tipi e i relativi metodi includono:
Alcuni degli overload generici del BinarySearch metodo .
Metodi di ricerca della List<T> classe , inclusi List<T>.Contains(T), List<T>.IndexOf, List<T>.LastIndexOfe List<T>.Remove.
Metodi di ricerca della Dictionary<TKey,TValue> classe , inclusi ContainsKey e Remove.
Metodi di ricerca della classe generica LinkedList<T> , inclusi LinkedList<T>.Contains e Remove.
In altre parole, per gestire la possibilità che gli oggetti di una classe vengano archiviati in una matrice o in un oggetto raccolta generico, è consigliabile implementare IEquatable<T> in modo che l'oggetto possa essere facilmente identificato e manipolato.
Quando si implementa il metodo, definire l'uguaglianza Equals in modo appropriato per il tipo specificato dall'argomento di tipo generico. Ad esempio, se l'argomento di tipo è Int32, definire l'uguaglianza in modo appropriato per il confronto di due interi con segno a 32 bit.
Note per gli implementatori
Se si implementa Equals(T), è anche necessario eseguire l'override delle implementazioni della classe di base di Equals(Object) e GetHashCode() in modo che il relativo comportamento sia coerente con quello del Equals(T) metodo . Se si esegue l'override di , l'implementazione sottoposta a override Equals(Object)viene chiamata anche nelle chiamate al metodo statico Equals(System.Object, System.Object)
nella classe . Inoltre, è necessario eseguire l'overload degli op_Equality
operatori e op_Inequality
. In questo modo tutti i test di uguaglianza restituiscono risultati coerenti, come illustrato nell'esempio.