c# ArrayList 的 Sort()方法的使用
2024-07-21 02:19:36
供稿:網友
關鍵字: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);
#結束