SortedList 類

表示鍵/值對的集合,這些鍵和值按鍵排序並可按照鍵和索引訪問。

SortedList最合適對一列健/值對 進行排序,在排序時,是對鍵進行排序,

SortedList Hashtable Array 的混合。當使用 Item 索引器屬性按照元素的鍵訪問元

素時,其行爲類似於 Hashtable。當使用 GetByIndex SetByIndex 按照元素的索引訪問元

素時,其行爲類似於 Array

SortedList 在內部維護兩個數組以將數組存儲到列表中;即,一個數組用於鍵,另一個數組

用於相關聯的值。每個元素都是一個可作爲 DictionaryEntry 對象進行訪問的鍵/值對。鍵不

能爲空引用(Visual Basic 中爲 Nothing),但值可以。

SortedList 的容量是列表可擁有的元素數。隨着向 SortedList 中添加元素,容量通過重新

分配按需自動增加。可通過調用 TrimToSize 或通過顯式設置 Capacity 屬性減少容量。

SortedList 的元素將按照特定的 IComparer 實現(在創建 SortedList 時指定)或按照鍵本

身提供的 IComparable 實現並依據鍵來進行排序。不論在哪種情況下,SortedList 都不允許

重複鍵。

索引順序基於排序順序。當添加元素時,元素將按正確的排序順序插入 SortedList,同時索

引會相應地進行調整。若移除了元素,索引也會相應地進行調整。因此,當在 SortedList

添加或移除元素時,特定鍵/值對的索引可能會更改。

由於要進行排序,所以在 SortedList 上操作比在 Hashtable

上操作要慢。但是,SortedList 允許通過相關聯鍵或通過索引對值進行訪問,可提供更大的

靈活性。

一。添加刪除

1public virtual void Add(object key,object value);

此集合中的索引從零開始。

將帶有指定鍵和值的元素添加到 SortedList

通過設置 SortedList 中不存在的鍵的值,Item

屬性也可用於添加新元素。例如:myCollection["myNonexistentKey"] = myValue。但是,如

果指定的鍵已經存在於 SortedList 中,則設置 Item 屬性將改寫舊值。相比之下,Add 方法

不修改現有元素。

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

//結果爲d c b a,所以可知是按鍵排序,而非值排序

DropDownList3.DataSource = sList;

DropDownList3.DataTextField = "Key";

DropDownList3.DataValueField = "Value";

DropDownList3.DataBind();

2public virtual void Remove(object key);

SortedList 中移除帶有指定鍵的元素

如果 SortedList 不包含帶有指定鍵的元素,則 SortedList 保持不變。不引發異常

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

//sList.Remove("b"); 錯誤,是按key刪除,而非Value

sList.Remove(3); //刪除了[3,"b"]

DropDownList3.DataSource = sList;

DropDownList3.DataTextField = "Key";

DropDownList3.DataValueField = "Value";

DropDownList3.DataBind();

3public virtual void RemoveAt(int index);

移除 SortedList 的指定索引處的元素。

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

sList.RemoveAt(3); //刪除的是[4"a"],這裏的參數是索引號,而非鍵值,

                   //sList.Remove(3)不同; sList.Remove(3)刪除了[3,"b"]

DropDownList3.DataSource = sList;

DropDownList3.DataTextField = "Key";

DropDownList3.DataValueField = "Value";

DropDownList3.DataBind();

4public virtual void Clear();

SortedList 中移除所有元素

Count 設置爲零。Capacity 保持不變。若要重置 SortedList 的容量,請調用 TrimToSize

或直接設置 Capacity 屬性。截去空 SortedList 會將 SortedList 的容量設置爲默認容量,

而不是零

二。與索引有關的操作

1public virtual void SetByIndex(int index,object value);

替換 SortedList 中指定索引處的值。

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

sList.SetByIndex(1,"dddddd"); //1爲索引,如果Count<2,則出錯,也就是說必須存在

                          //sList[2] = "dddddd";不存在這種現象,

                            //也就是說sList[2] = "dddddd"

                               //如果鍵存在在修改值,不存在則添加

DropDownList3.DataSource = sList;

DropDownList3.DataTextField = "Key";

DropDownList3.DataValueField = "Value";

DropDownList3.DataBind();

2public virtual object GetByIndex(int index);

獲取 SortedList 的指定索引處的值。

index必須小於Count,否則出錯

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

//sList.Clear();

int nIndex = 2;

if (nIndex<sList.Count)

 {

   Label3.Text = sList.GetByIndex(nIndex).ToString();

 }

else

 {

 Label3.Text = "nIndex>=Count";

 }

 

 

3.public virtual int IndexOfKey(object key);

返回 SortedList 中指定鍵的從索引

這是Hashtable所沒有的,因爲Hashtable沒有有序這個概念,它的排序是內部的

 

 

4.public virtual int IndexOfValue(object value);

返回指定的值在 SortedList 中第一個匹配項的索引

這是Hashtable所沒有的,因爲Hashtable沒有有序這個概念,它的排序是內部的

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

sList.Add(5,"d");

int nIndex = 0;

nIndex = sList.IndexOfKey(1); //0

nIndex = sList.IndexOfValue("d"); //值匹配的有兩個,這時返回第一個匹配的,所以爲0

 

 

三。其他

1.public virtual object GetKey(int index);

獲取 SortedList 的指定索引處的鍵

這也是Hashtable所不可能有的

 

 

2.public virtual IList GetKeyList();

獲取 SortedList 中的鍵

SortedList sList = new SortedList();

sList.Add(1,"d");

sList.Add(2,"c");

sList.Add(3,"b");

sList.Add(4,"a");

sList.Add(5,"d");

Label3.Text = "";

IList iList = sList.GetKeyList();

for (int i=0; i<sList.Count; i++)

{

 Label3.Text += iList[i].ToString();

 Label3.Text += " ";

}

注:IList 接口,表示可按照索引單獨訪問的一組對象,其中有一個Item屬性,在C#也就就是

索引器

 

 

3.public virtual IList GetValueList();

獲取 SortedList 中的值

 

 

4.public virtual bool Contains(object key);

確定 SortedList 是否包含特定鍵

 

 

5.public virtual bool ContainsKey(object key);

確定 SortedList 是否包含特定鍵

Contains(object key);完全同

6.public virtual bool ContainsValue(object value);

確定 SortedList 是否包含特定值

上述這三個函數與Hashtable完全相同

 

 

7.public virtual void TrimToSize();

將容量設置爲 SortedList 中元素的實際數目

 

 

 

 

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章