Questo articolo è stato tradotto automaticamente. Per visualizzare l'articolo in inglese, selezionare la casella di controllo Inglese. È possibile anche visualizzare il testo inglese in una finestra popup posizionando il puntatore del mouse sopra il testo.
Traduzione
Inglese

Metodo Tuple<T1, T2, T3, T4, T5, T6>.IStructuralEquatable.Equals (Object, IEqualityComparer)

 

Data di pubblicazione: ottobre 2016

Restituisce un valore che indica se l'oggetto corrente Tuple<T1, T2, T3, T4, T5, T6> oggetto è uguale all'oggetto specificato in base a un metodo di confronto specificato.

Spazio dei nomi:   System
Assembly:  mscorlib (in mscorlib.dll)

bool IStructuralEquatable.Equals(
	object other,
	IEqualityComparer comparer
)

Parametri

other
Type: System.Object

Oggetto da confrontare con questa istanza.

comparer
Type: System.Collections.IEqualityComparer

Oggetto che definisce il metodo da utilizzare per valutare se i due oggetti sono uguali.

Valore restituito

Type: System.Boolean

true Se l'istanza corrente è uguale all'oggetto specificato. in caso contrario, false.

Questo membro è un'implementazione esplicita di un membro di interfaccia. e può essere utilizzato solo quando si esegue il cast dell'istanza di Tuple<T1, T2, T3, T4, T5, T6> su un'interfaccia IStructuralEquatable.

Il IEqualityComparer.Equals implementazione viene chiamato solo se other non null, e se può essere correttamente il cast (in c#) o convertire (in Visual Basic) per un Tuple<T1, T2, T3, T4, T5, T6> oggetto i cui componenti sono dello stesso tipo dell'istanza corrente. Il IStructuralEquatable.Equals(Object, IEqualityComparer) passa primo metodo di Item1 valori del Tuple<T1, T2, T3, T4, T5, T6> oggetti da confrontare con il IEqualityComparer.Equals implementazione. Se questa chiamata al metodo restituisce true, il metodo viene chiamato nuovamente e passato il Item2 i valori dei due Tuple<T1, T2, T3, T4, T5, T6> oggetti. Il processo continua finché la chiamata al metodo restituisce false quando viene confrontata una coppia specifica di Item valori o i due Item6 i valori vengono passati al metodo.

L'esempio seguente definisce una RateComparer classe che esegue un test personalizzato per l'uguaglianza. Se i valori passati ai relativi IStructuralEquatable.Equals metodo sono di tipo Single o Double, il metodo verifica l'uguaglianza utilizzando un massimo di tre cifre frazionarie. In caso contrario, chiama semplicemente il x del parametro Equals metodo. Nell'esempio viene utilizzato questo IEqualityComparer implementazione per determinare se quattro Tuple<T1, T2, T3, T4, T5, T6> oggetti che contengono dati sulla frequenza di variazione della popolazione tra 1960 e 2000 sono uguali.

using System;
using System.Collections;

public class RateComparer<T1, T2, T3, T4, T5, T6> : IEqualityComparer
{
   private int argument = 0;

   public new bool Equals(object x, object y) 
   {
      argument++;
      if (argument == 1) return true;

      double fx, fy; 
      if (x is Double || x is Single)
      {
            fx = (double) x;
            fy = (double) y;
            return Math.Round(fx * 1000).Equals(Math.Round(fy * 1000));
      }
      else
      {
         return x.Equals(y);
      }
   }

   public int GetHashCode(object obj)
   {
      if (obj is Single || obj is Double)
         return Math.Round(((double) obj) * 1000).GetHashCode();
      else
         return obj.GetHashCode();
   }                
}

public class Example
{
   public static void Main()
   {
      var rate1 = Tuple.Create("New York", .014505, -.1042733, 
                               .0354833, .093644, .0290792);
      var rate2 = Tuple.Create("Unknown City", .014505, -.1042733, 
                               .0354833, .093644, .0290792);
      var rate3 = Tuple.Create("Unknown City", .014505, -.1042733, 
                               .0354833, .093644, .029079);
      var rate4 = Tuple.Create("San Francisco", -.0332858, -.0512803, 
                               .0662544, .0728964, .0491912);
      IStructuralEquatable eq = rate1;
      // Compare first tuple with remaining two tuples.
      Console.WriteLine("{0} = ", rate1.ToString());
      Console.WriteLine("   {0} : {1}", rate2, 
                        eq.Equals(rate2, new RateComparer<string, double, double, double, double, double>()));
      Console.WriteLine("   {0} : {1}", rate3, 
                        eq.Equals(rate3, new RateComparer<string, double, double, double, double, double>()));
      Console.WriteLine("   {0} : {1}", rate4, 
                        eq.Equals(rate4, new RateComparer<string, double, double, double, double, double>()));
   }
}
// The example displays the following output:
//    (New York, 0.014505, -0.1042733, 0.0354833, 0.093644, 0.0290792) =
//       (Unknown City, 0.014505, -0.1042733, 0.0354833, 0.093644, 0.0290792) : True
//       (Unknown City, 0.014505, -0.1042733, 0.0354833, 0.093644, 0.029079) : True
//       (San Francisco, -0.0332858, -0.0512803, 0.0662544, 0.0728964, 0.0491912) : False

Universal Windows Platform
Disponibile da 8
.NET Framework
Disponibile da 4.0
Libreria di classi portabile
Supportato in: piattaforme .NET portabili
Silverlight
Disponibile da 4.0
Windows Phone Silverlight
Disponibile da 8.0
Windows Phone
Disponibile da 8.1
Torna all'inizio
Mostra: