LinkedList<T>是一個雙向鏈表,其元素會指向它前面和后面的元素。這樣,通過移動到下一個元素可以正向遍歷鏈表,通過移動到前一個元素可以反向遍歷鏈表。
  photoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)
  鏈表在存儲元素時,不僅要存儲元素的值,還必須存儲每個元素的下一個元素和上一個元素的信息。這就是LinkedList<T>包含LinkedListNode<T>類型的元素的原因。使用LinkedListNode<T>,可以獲得列表中的下一個和上一個元素。LinkedListNode<T>定義了屬性List,Next,Previous和Value。List屬性返回與節(jié)點相關(guān)的LinkedList<T>對象。Next和Previous屬性用于遍歷鏈表,訪問當(dāng)前節(jié)點之后和之前的節(jié)點。Value屬性返回與節(jié)點相關(guān)的元素,其類型是T。
  鏈表的優(yōu)點是,如果將元素插入到列表的中間位置,使用鏈表就會很快。在插入一個元素時,秩序啊喲修改上一個元素的Next引用和下一個元素的Previous引用,使它們引用所插入的元素。在  List<T>(http://www.cnblogs.com/afei-24/p/6824791.html)中,插入一個元素,需要移動該元素后面的所以元素。
  鏈表的缺點是,鏈表元素只能一個接一個的訪問,這需要較長時間來查找位于鏈表中間或尾部的元素。

  LinkedList<T>類定義的成員可以訪問鏈表中的第一個和最后一個元素(First和Last);
  在指定位置插入元素:AddAfter(),AddFirst()和AddLast();
  刪除指定位置的元素:Remove(),RemoveFirst(),RemoveLast();
  搜索:Find(),F(xiàn)indLast()。

  下面用一個例子演示鏈表。在鏈表中,文檔按照優(yōu)先級來排序。如果多個文檔的優(yōu)先級相同,這些元素就按照文檔的插入時間來排序:
  PriorityDocumentManager類使用一個鏈表LinkedList<Document> documentList和一個列表List<LinkedListNode<Document>> priorityNodes,鏈表包含Document對象,Document對象包含文檔的標(biāo)題和優(yōu)先級。列表List<LinkedListNode<Document>> priorityNodes應(yīng)最多包含10個元素,每個元素分別是引用每個優(yōu)先級的最后一個文檔對象。
  photoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)

網(wǎng)友評論