您好,登錄后才能下訂單哦!
C#中IComparable和IComparer的區別是什么,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
IComparable接口
該接口由其值可以排序或排序的類型實現,并提供強類型的比較方法以對泛型集合對象的成員進行排序,例如數字可以大于第二個數字,一個字符串可以在另一個字符串之前以字母順序出現。他要求實現類型定義的一個方法,CompareTo(T)該方法指示當前實現在排序順序中的位置是在同一個類型和第二個對象之前、之后還是與其相同。通常,不會直接從開發人員代碼中調用方法。相反他由List .Sort()和Add等方法自動調用。
通常,提供Icomparable 實現的類型還IEquatable 實現接口。IEquatable 接口Equals定義方法,該方法確定實現類型的實例的相等性。
CompareTo(T)方法的實現必須Int32返回具有以下三個值之一的,如下表所示。
小于零 此對象在排序順序中位于CompareTo方法所指定的對象之前。 零 此當前實例在排序順序中與CompareTo方法參數指定的對象出現在同一位置。 大于零 此當前實例位于排序順序中由CompareTo方法自變量指定的對象之后。
示例:
class Student : IComparable { public string Name { get; set; } public int Age { get; set; } public int CompareTo(object obj) { if (!(obj is Student)) { throw new ArgumentException("Compared Object is not of student"); } Student student = obj as Student; return Age.CompareTo(student.Age); } }
值 | 含義 |
---|
Ps:我們根據通過Age(int)來進行我們的排序
執行測試
class Program { static void Main(string[] args) { ArrayList studentList = new ArrayList { new Student{Name="a",Age=9 }, new Student{Name="a3",Age=7 }, new Student{Name="a1",Age=6 }, new Student{Name="a2",Age=10 }, }; studentList.Sort(); StudentComparable(studentList); Console.ReadLine(); } private static void StudentComparable(ArrayList studentList) { foreach (Student item in studentList) { Console.WriteLine("Name:{0},Age:{1}", item.Name, item.Age); } } }
輸出如下
IComparer接口
IComparable 接口的CompareTo方法一次只能對一個字段進行排序,因此無法對不同的屬性進行排序。IComparer接口提供了Compare方法,該方法比較兩個對象并返回一個值,該值指示一個對象小于,等于或大于另一個對象。實現IComparer接口的類必須提供比較兩個對象的Compare方法。例如,您可以創建一個StudentComparer類,該類實現IComparer,并具有一個Compare方法,該方法按Name比較Student對象。然后,您可以將StudentComparer對象傳遞給Array.Sort方法,它可以使用該對象對Student對象的數組進行排序。
示例
class StudentComparer : IComparer { public int Compare(object x, object y) { Student x1 = x as Student; Student y1 = y as Student; return x1.Name.CompareTo(y1.Name); } }
Ps:我們根據Name(string)進行排序
執行測試
class Program { static void Main(string[] args) { ArrayList studentList = new ArrayList { new Student{Name="a",Age=9 }, new Student{Name="a3",Age=7 }, new Student{Name="a1",Age=6 }, new Student{Name="a2",Age=10 }, }; studentList.Sort(new StudentComparer()); StudentComparable(studentList); Console.ReadLine(); } private static void StudentComparable(ArrayList studentList) { foreach (Student item in studentList) { Console.WriteLine("Name:{0},Age:{1}", item.Name, item.Age); } } }
輸出結果如下
IComparable 和IComparer
上述示例中我們將對象進行了多次的裝箱和拆箱,那么此時我們可以將方法改為泛型的,泛型的出現也讓我們避免了裝箱和拆箱的資源浪費.
最終我們實現的代碼片段如下:
IComparable
class Student : IComparable<Student> { public string Name { get; set; } public int Age { get; set; } public int CompareTo([AllowNull] Student other) { return Age.CompareTo(other.Age); } }
IComparer
class StudentComparer : IComparer<Student> { public int Compare([AllowNull] Student x, [AllowNull] Student y) { return x.Name.CompareTo(y.Name); } }
關于C#中IComparable和IComparer的區別是什么問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。