Comparer<T>.IComparer.Compare(Object, Object) Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Compara dois objetos e retorna um valor que indica se um é menor que, igual ou maior que o outro.
virtual int System.Collections.IComparer.Compare(System::Object ^ x, System::Object ^ y) = System::Collections::IComparer::Compare;
int IComparer.Compare(object x, object y);
abstract member System.Collections.IComparer.Compare : obj * obj -> int
override this.System.Collections.IComparer.Compare : obj * obj -> int
Function Compare (x As Object, y As Object) As Integer Implements IComparer.Compare
Parâmetros
- x
- Object
O primeiro objeto a ser comparado.
- y
- Object
O segundo objeto a ser comparado.
Retornos
Um inteiro com sinal que indica os valores relativos de x e y, conforme mostrado na tabela a seguir.
| Valor | Significado |
|---|---|
| Menor que zero |
x é menor que y.
|
| Zero |
x igual a y.
|
| Maior que zero |
x é maior que y.
|
Implementações
Exceções
x ou y é de um tipo que não pode ser convertido em tipo T.
- ou -
x e y não implemente a IComparable<T> interface genérica ou a IComparable interface.
Exemplos
O exemplo a seguir mostra como usar o IComparer.Compare método para comparar dois objetos. Este exemplo faz parte de um exemplo maior fornecido para a Comparer<T> classe.
// This explicit interface implementation
// compares first by the length.
// Returns -1 because the length of BoxA
// is less than the length of BoxB.
BoxLengthFirst LengthFirst = new BoxLengthFirst();
Comparer<Box> bc = (Comparer<Box>) LengthFirst;
Box BoxA = new Box(2, 6, 8);
Box BoxB = new Box(10, 12, 14);
int x = LengthFirst.Compare(BoxA, BoxB);
Console.WriteLine();
Console.WriteLine(x.ToString());
// This explicit interface implementation
// compares first by the length.
// Returns -1 because the length of BoxA
// is less than the length of BoxB.
let LengthFirst = BoxLengthFirst()
let bc = LengthFirst :> Comparer<Box>
let BoxA = Box(2, 6, 8)
let BoxB = Box(10, 12, 14)
let x = LengthFirst.Compare(BoxA, BoxB)
printfn $"\n{x}"
' This explicit interface implementation
' compares first by the length.
' Returns -1 because the length of BoxA
' is less than the length of BoxB.
Dim LengthFirst As New BoxLengthFirst()
Dim bc As Comparer(Of Box) = CType(LengthFirst, Comparer(Of Box))
Dim BoxA As New Box(2, 6, 8)
Dim BoxB As New Box(10, 12, 14)
Dim x As Integer = LengthFirst.Compare(BoxA, BoxB)
Console.WriteLine()
Console.WriteLine(x.ToString())
Comentários
Esse método é um wrapper para o Compare(T, T) método, portanto obj , deve ser convertido no tipo especificado pelo argumento T genérico da instância atual. Se não puder ser convertido T, um ArgumentException será lançado.
A comparação null com qualquer tipo de referência é permitida e não gera uma exceção. Ao classificar, null é considerado menor que qualquer outro objeto.
Notas aos Chamadores
Compare(T, T) e Equals(T, T) se comporte de forma diferente em termos de confidencialidade de cultura e diferenciação de maiúsculas e minúsculas.
Para comparações de cadeia de caracteres, a StringComparer classe é recomendada em .Comparer<String> As propriedades da StringComparer classe retornam instâncias predefinidas que executam comparações de cadeia de caracteres com combinações diferentes de confidencialidade de cultura e diferenciação de maiúsculas e minúsculas. A sensibilidade de maiúsculas e minúsculas e a sensibilidade à cultura são consistentes entre os membros da mesma StringComparer instância.
Para obter mais informações sobre comparações específicas à cultura, consulte o System.Globalization namespace e a globalização e a localização.