關鍵字:ArrayList ,IComparer,接口,C#
我看見網上有人問IComparer接口的使用,於是寫了個小例子,和大家一塊分享。有不足之處,望不吝指正
1、建一個結構雇員的結構
private struct Eployee{
public string name;
public int age;
public string sex;
}
2、新建3個"雇員"
Eployee ep1=new Eployee();
ep1.name="小張";
ep1.age=21;
ep1.sex="男";
Eployee ep2=new Eployee();
ep2.name="老李";
ep2.age=43;
ep2.sex="男";
Eployee ep3=new Eployee();
ep3.name="施施";
ep3.age=18;
ep3.sex="男";
3、將3個"雇員" 加入"雇員列表";
ArrayList EmployeeList=new ArrayList();
EmployeeList.Add(ep1);
EmployeeList.Add(ep2);
EmployeeList.Add(ep3);
好了一切准備就緒,現在希望EmployeeList中得"雇員"是按年齡排序的。
咋辦呢?
其實很簡單,我們沒必要自己去實現某個排序方法,冒泡或其他什麼的。ArrayList 提供了我們現成的排序方法Sort();
它有三個重載,不管使用哪一個,至少要你提供一個Comparer:IComparer;來告訴Sort方法 你對"雇員"們的排序依據。
這個Comparer必須實現接口:System.Collections.IComparer ,該接口只有一個成員函數需要你去實現。
描述如下:
[Visual Basic]
Function Compare( _
ByVal x As Object, _
ByVal y As Object _
) As Integer
[C#]
int Compare(
object x,
object y
);
[C++]
int Compare(
Object* x,
Object* y
);
[JScript]
function Compare(
x : Object,
y : Object
) : int;
(可以去參考msdn)
知道了這些那我們來實現一個吧
private class myEmployeeCompare:System.Collections.IComparer {
public int Compare(object x,object y){
return ((Eployee)x).age-((Eployee)y).age;
}
}
因為我們比較的是“雇員”的age,所以我們可以放心的寫實現語句
return ((Eployee)x).age-((Eployee)y).age;
myEmployeeCompare EmployeeCompare=new myEmployeeCompare();
ok現在我們可以對"雇員"們按年齡排序了
EmployeeList.Sort(EmployeeCompare);
#結束