Leer en inglés

Compartir a través de


IComparable.CompareTo(Object) Método

Definición

Compara la instancia actual con otro objeto del mismo tipo y devuelve un entero que indica si la instancia actual precede, sigue o se produce en la misma posición en el criterio de ordenación que el otro objeto.

C#
public int CompareTo(object obj);
C#
public int CompareTo(object? obj);

Parámetros

obj
Object

Objeto que se va a comparar con esta instancia.

Devoluciones

Valor que indica el orden relativo de los objetos que se comparan. El valor devuelto tiene estos significados:

Valor Significado
Menor que cero Esta instancia precede a obj en el criterio de ordenación.
Cero Esta instancia se produce en la misma posición en el criterio de ordenación que obj.
Mayor que cero Esta instancia sigue obj en el criterio de ordenación.

Excepciones

obj no es el mismo tipo que esta instancia.

Ejemplos

En el ejemplo siguiente se muestra el uso de CompareTo para comparar un objeto Temperature que implementa IComparable con otro objeto . El objeto Temperature implementa CompareTo simplemente ajustando una llamada al método Int32.CompareTo.

C#
using System;
using System.Collections;

public class Temperature : IComparable
{
    // The temperature value
    protected double temperatureF;

    public int CompareTo(object obj) {
        if (obj == null) return 1;

        Temperature otherTemperature = obj as Temperature;
        if (otherTemperature != null)
            return this.temperatureF.CompareTo(otherTemperature.temperatureF);
        else
           throw new ArgumentException("Object is not a Temperature");
    }

    public double Fahrenheit
    {
        get
        {
            return this.temperatureF;
        }
        set 
        {
            this.temperatureF = value;
        }
    }

    public double Celsius
    {
        get
        {
            return (this.temperatureF - 32) * (5.0/9);
        }
        set
        {
            this.temperatureF = (value * 9.0/5) + 32;
        }
    }
}

public class CompareTemperatures
{
   public static void Main()
   {
      ArrayList temperatures = new ArrayList();
      // Initialize random number generator.
      Random rnd = new Random();

      // Generate 10 temperatures between 0 and 100 randomly.
      for (int ctr = 1; ctr <= 10; ctr++)
      {
         int degrees = rnd.Next(0, 100);
         Temperature temp = new Temperature();
         temp.Fahrenheit = degrees;
         temperatures.Add(temp);
      }

      // Sort ArrayList.
      temperatures.Sort();

      foreach (Temperature temp in temperatures)
         Console.WriteLine(temp.Fahrenheit);
   }
}
// The example displays the following output to the console (individual
// values may vary because they are randomly generated):
//       2
//       7
//       16
//       17
//       31
//       37
//       58
//       66
//       72
//       95

Comentarios

El método CompareTo se implementa mediante tipos cuyos valores se pueden ordenar o ordenar. Se llama automáticamente mediante métodos de objetos de colección no genéricos, como Array.Sort, para ordenar cada miembro de la matriz. Si una clase o estructura personalizada no implementa IComparable, sus miembros no se pueden ordenar y la operación de ordenación puede iniciar un InvalidOperationException.

Este método es solo una definición y debe implementarse mediante una clase o tipo de valor específico para tener efecto. El significado de las comparaciones especificadas en la sección Valor devuelto ("precede", "se produce en la misma posición que" y "sigue") depende de la implementación concreta.

Por definición, cualquier objeto compara mayor que (o sigue) null, y dos referencias nulas se comparan entre sí.

El parámetro, obj, debe ser el mismo tipo que la clase o el tipo de valor que implementa esta interfaz; De lo contrario, se produce un ArgumentException.

Notas a los implementadores

Para los objetos A, B y C, debe ser true:

A.CompareTo(A) debe devolver cero.

Si A.CompareTo(B) devuelve cero, B.CompareTo(A) debe devolver cero.

Si A.CompareTo(B) devuelve cero y B.CompareTo(C) devuelve cero, A.CompareTo(C) debe devolver cero.

Si A.CompareTo(B) devuelve un valor distinto de cero, B.CompareTo(A) debe devolver un valor del signo opuesto.

Si A.CompareTo(B) devuelve un valor "x" no igual a cero y B.CompareTo(C) devuelve un valor "y" del mismo signo que "x", A.CompareTo(C) debe devolver un valor del mismo signo que "x" e "y".

Notas a los autores de las llamadas

Use el método CompareTo(Object) para determinar el orden de las instancias de una clase.

Se aplica a

Producto Versiones
.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, 10
.NET Framework 1.1, 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

Consulte también