String.IComparable.CompareTo(Object) Método

Definição

Compara esta instância com um especificado Object e indica se esta instância precede, segue ou aparece na mesma posição na ordem de ordenação que o especificado Object.

 virtual int System.IComparable.CompareTo(System::Object ^ value) = IComparable::CompareTo;
int IComparable.CompareTo(object value);
abstract member System.IComparable.CompareTo : obj -> int
override this.System.IComparable.CompareTo : obj -> int
Function CompareTo (value As Object) As Integer Implements IComparable.CompareTo

Parâmetros

value
Object

Um objeto que avalia para um String.

Devoluções

Um inteiro assinado de 32 bits que indica se esta instância precede, segue ou aparece na mesma posição na ordem de ordenação do value parâmetro.

ValueCondition
Menor que zeroEsta instância precede value.
ZeroEsta instância tem a mesma posição na ordem de ordenação que value.
Maior que zeroEsta instância segue value, ou value é null.

Implementações

Exceções

value não é um String.

Exemplos

O exemplo seguinte utiliza o CompareTo método com um Object. Como tenta comparar uma String instância com um TestClass objeto, o método gera um ArgumentException.

using System;

public class TestClass
{}

public class Example
{
   public static void Main()
   {
      var test = new TestClass();
      Object[] objectsToCompare = { test, test.ToString(), 123,
                                    123.ToString(), "some text",
                                    "Some Text" };
      string s = "some text";
      foreach (var objectToCompare in objectsToCompare) {
         try {
            int i = s.CompareTo(objectToCompare);
            Console.WriteLine("Comparing '{0}' with '{1}': {2}",
                              s, objectToCompare, i);
         }
         catch (ArgumentException) {
            Console.WriteLine("Bad argument: {0} (type {1})",
                              objectToCompare,
                              objectToCompare.GetType().Name);
         }
      }
   }
}
// The example displays the following output:
//    Bad argument: TestClass (type TestClass)
//    Comparing 'some text' with 'TestClass': -1
//    Bad argument: 123 (type Int32)
//    Comparing 'some text' with '123': 1
//    Comparing 'some text' with 'some text': 0
//    Comparing 'some text' with 'Some Text': -1
open System

type TestClass() = class end

let test = TestClass()
let objectsToCompare: obj list =
    [ test; string test; 123
      string 123; "some text"
      "Some Text" ]
let s = "some text"
for objectToCompare in objectsToCompare do
    try
        let i = s.CompareTo objectToCompare
        printfn $"Comparing '{s}' with '{objectToCompare}': {i}"
    with :? ArgumentException ->
        printfn $"Bad argument: {objectToCompare} (type {objectToCompare.GetType().Name})"
// The example displays the following output:
//    Bad argument: TestClass (type TestClass)
//    Comparing 'some text' with 'TestClass': -1
//    Bad argument: 123 (type Int32)
//    Comparing 'some text' with '123': 1
//    Comparing 'some text' with 'some text': 0
//    Comparing 'some text' with 'Some Text': -1
Public Class TestClass
End Class 


Public Class Example
   Public Shared Sub Main()
      Dim test As New TestClass()
      Dim objectsToCompare() As Object = { test, test.ToString(), 123,
                                           123.ToString(), "some text",
                                           "Some Text" }
      Dim s As String = "some text"
      For Each objectToCompare In objectsToCompare
         Try
            Dim i As Integer = s.CompareTo(objectToCompare)
            Console.WriteLine("Comparing '{0}' with '{1}': {2}",
                              s, objectToCompare, i)
         Catch e As ArgumentException
            Console.WriteLine("Bad argument: {0} (type {1})",
                              objectToCompare,
                              objectToCompare.GetType().Name)
         End Try
      Next
   End Sub 
End Class 
' The example displays the following output:
'       Bad argument: TestClass (type TestClass)
'       Comparing 'some text' with 'TestClass': -1
'       Bad argument: 123 (type Int32)
'       Comparing 'some text' with '123': 1
'       Comparing 'some text' with 'some text': 0
'       Comparing 'some text' with 'Some Text': -1

Observações

value Deve ser um String objeto.

Atenção

O CompareTo método foi concebido principalmente para operações de ordenação ou ordenação alfabética. Não deve ser usado quando o objetivo principal da chamada de método é determinar se duas cadeias são equivalentes. Para determinar se duas cadeias são equivalentes, chama-se o Equals método.

Este método realiza uma comparação de palavras (sensível a maiúsculas minúsculas e culturas) usando a cultura atual. Para mais informações sobre ordenações de palavra, cadeia e ordinais, veja System.Globalization.CompareOptions.

Para mais informações sobre o comportamento deste método, consulte a secção de Observações do String.Compare(String, String) método.

Aplica-se a