이 문서는 기계 번역을 이용하여 번역되었습니다. 문서를 영문으로 보려면 영문 확인란을 선택하세요. 마우스 포인터를 텍스트 위로 이동시켜 팝업 창에서 영문 텍스트를 표시할 수도 있습니다.
번역
영문

IComparable 인터페이스

 

게시 날짜: 2016년 11월

값 형식 또는 클래스에서 해당 인스턴스를 정렬 및 순서 지정하기 위해 구현하는 일반화된 형식별 비교 메서드를 정의합니다.

네임스페이스:   System
어셈블리:  mscorlib(mscorlib.dll에 있음)

[ComVisibleAttribute(true)]
public interface IComparable

이름설명
System_CAPS_pubmethodCompareTo(Object)

현재 인스턴스와 동일한 형식의 다른 개체를 비교하고 정렬 순서에서 현재 인스턴스의 위치가 다른 개체보다 앞인지, 뒤인지 또는 동일한지를 나타내는 정수를 반환합니다.

이 인터페이스는 해당 값을 정렬 하거나 정렬할 수 형식에서 구현 됩니다. 구현 형식, 단일 메서드에서 정의 필요 CompareTo(Object), 하 고 정렬 순서에서 현재 인스턴스의 위치 인지 나타내는 이전에 뒤 동일한 형식의 두 번째 개체와 동일 합니다. 인스턴스의 IComparable 구현 메서드에서 호출 됩니다 자동으로 같은 Array.SortArrayList.Sort합니다.

구현에서 CompareTo(Object) 메서드 반환 해야 합니다는 Int32 된 세 값 중 하나는 다음 표에 나와 있는 것 처럼 합니다.

의미

0보다 작음

현재 인스턴스가 지정한 개체 앞에 CompareTo 정렬 순서에서 메서드.

0

이 현재 인스턴스에 지정한 개체와 정렬 순서에서 같은 위치에서 발생 된 CompareTo 메서드.

0보다 큼

이 현재 인스턴스에 의해 지정 된 개체 다음에 오는 CompareTo 정렬 순서에서 메서드.

모든 숫자 형식 (예: Int32Double) 구현 IComparableString, Char, 및 DateTime합니다. 사용자 지정 형식을의 자체 구현을 제공 해야 IComparable 개체 인스턴스 순서를 지정 하거나 정렬할 수를 사용할 수 있도록 합니다.

다음 예제에는의 구현 방법을 보여 줍니다. IComparable 필수 CompareTo 메서드.

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

유니버설 Windows 플랫폼
8 이후 사용 가능
.NET Framework
1.1 이후 사용 가능
이식 가능한 클래스 라이브러리
이식 가능한 .NET 플랫폼 에서 지원됨
Silverlight
2.0 이후 사용 가능
Windows Phone Silverlight
7.0 이후 사용 가능
Windows Phone
8.1 이후 사용 가능
맨 위로 이동
표시: