在前面的專欄中,我討論了.net數組的基本功能。本周,我們對這個主題進行擴充,著重討論數組內容的分類。array類提供了sort方法,這個方法具有各種用途。我從簡單的方法開始討論,再以自定義分類結束。
sort方法
使用array類的靜態sort方法是分類數組內容的最簡單方法。列表a通過對一組姓名進行分類,說明如何應用這個方法。
它生成了下面的結果,它顯示了調用分類方法前后的姓名列表:
0. howard, ryan
1. allen, ray
2. pujols, albert
3. iverson, allen
0. allen, ray
1. howard, ryan
2. iverson, allen
3. pujols, albert
下面是對應的vb.net代碼:
dim x as integer
dim names(3) as string
names(0) = "howard, ryan"
names(1) = "allen, ray"
names(2) = "pujols, albert"
names(3) = "iverson, allen"
for x = 0 to (names.length - 1)
console.writeline(cstr(x) + ". " + names(x).tostring())
next x
array.sort(names)
for x = 0 to (names.length - 1)
console.writeline(cstr(x) + ". " + names(x).tostring())
next x
array類的sort方法能夠以各種形式對數組內容進行分類。既然你了解了這個方法的最簡單應用形式,下面給出它的其它一些用途:
sort(array, array);根據第一個數組中的鍵對一對一維數組(一個包含鍵,另一個包含對應的項目)對象進行分類。
sort(array, icomparable):用指定的icomparable接口分類一個一維數組中的元素。
sort(array, array, icomparable):用指定的icomparable接口根據第一個數組中的鍵對一對一維數組(一個包含鍵,另一個包含對應的項目)對象進行分類。
sort(array, integer, integer):對一個一維數組指定起點與終點位置(整數值)的某個部分中的元素進行分類。
sort(array, array, integer, integer):根據第一個數組中的鍵對一對一維數組(一個包含鍵,另一個包含對應的項目)對象的某個部分進行分類。
sort(array, integer, integer, icomparable):用指定的icomparable接口對一個一維數組某一部分中的元素進行分類。
sort(array, array, integer, integer, icomparable):用指定的icomparable接口根據第一個數組中的鍵對一對一維數組(一個包含鍵,另一個包含對應的項目)對象的某個部分進行分類。
你可以應用array類的默認行為對整個數組和一個數組的某個部分進行分類;你還可以通過一個特殊的icomparable接口指定詳細的分類方法。列表b中的例子使用了兩個數組,一個數組包含鍵而另一個數組包含要分類的相應項目。它和增加鍵數組的第一個例子相同。
得到的結果是根據鍵數組中的值分類的數組值(第二個數組在調用sort方法時指定)。列表c中是對應的vb.net代碼。
你可以對代碼稍微進行一些調整,調用適當的sort方法,使它只分類一個對象。下面的代碼利用前一個例子,但只對數組中的第二和第三個元素進行分類。
int[] keys = new int[4];
keys[0] = 11;
keys[1] = 3;
keys[2] = 8;
keys[3] = 5;
string[] names = new string[4];
names[0] = "howard, ryan";
names[1] = "allen, ray";
names[2] = "pujols, albert";
names[3] = "iverson, allen";
array.sort(keys, names, 1, 2);
下面是對應的vb.net代碼:
dim keys(3) as integer
keys(0) = 11
keys(1) = 3
keys(2) = 8
keys(3) = 5
dim names(3) as string
names(0) = "howard, ryan"
names(1) = "allen, ray"
names(2) = "pujols, albert"
names(3) = "iverson, allen"
array.sort(keys, names, 1, 2)
分類自定義對象
雖然簡單的sort方法十分方便,但你不能使用它對自定義數據類型的數組進行自動分類。畢竟,你不能指望.net平臺了解所有建立的對象!但是,你仍然能夠使用icomparer或icomparable接口說明自定義對象的分類方法。
這些接口為你提供一個比較對象實例的方法,從而使分類更加方便。這兩個接口的主要不同在于:在使用icomparable接口時必須把比較方法包括在類中,而使用icomparer時則不必這樣。兩個接口的使用細節不在本文的討論范圍之內,不過下面我將用icomparable接口對一個自定義類數組進行分類。
在列表d中,我利用icomparable接口處理分類邏輯和它的類。如代碼所示,我建立了一個person類。注意,它使用icomparable接口并(在分類時)用compareto方法來進行比較。
在下一個例子中,建立一個person數組對象時,又用到這個類。(icomparable接口所需要的)compareto方法是對person類進行分類的關鍵,它將提交的對象與自身進行比較。接下來,再調用數組的sort方法,利用person類的分類機制,根據數組中每個對象的第一個名稱屬性進行其中的項目進行分類。列表e中是所使用且進行了分類的person對象。列表f中是對應的vb.net代碼,它首先列出了person類。
各種選擇
任何數據似乎都要進行分類。畢竟,人們喜歡看到數據以邏輯方式顯示。.net的array類提供了sort方法,利用它的值或一個單獨的關鍵值數組來簡化數組內容的分類過程。另外,你還可以應用icomparable接口之類的其它.net功能進行自定義分類。
新聞熱點
疑難解答
圖片精選