• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • 如何用.NET Array類的Sort方法分類數值

    發表于:2007-04-22來源:作者:點擊數: 標簽:Array類的Sortnbsp何用
    在前面的專欄中,我討論了.NET數組的基本功能。本周,我們對這個主題進行擴充,著重討論數組內容的分類。Array類提供了Sort方法,這個方法具有各種用途。我從簡單的方法開始討論,再以自定義分類結束。 Sort方法 使用Array類的靜態Sort方法是分類數組內容的
    在前面的專欄中,我討論了.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功能進行自定義分類

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>