C 中陣列 ArrayList和List三者的區別

2021-08-01 14:31:11 字數 2446 閱讀 3966

在c#中,當我們想要儲存一組物件的時候,就會想到用陣列,arraylist,list這三個物件了。那麼這三者到底有什麼樣的區別呢?

我們先來了解一下陣列,因為陣列在c#中是最早出現的。

陣列有很多的優點,比如說陣列在記憶體中是連續儲存的,所以它的索引速度是非常的快,而且賦值與修改元素也很簡單,比如:

string s=new

string[3

];//

賦值s[0]="a"

;s[1]="b"

;s[2]="c"

;//修改s[1]="

b1";

但是,陣列也存在一些不足的地方。比如在陣列的兩個資料間插入資料也是很麻煩的。還有我們在宣告陣列的時候,必須同時指明陣列的長度,陣列的長度過長,會造成記憶體浪費,陣列和長度過短,會造成資料溢位的錯誤。這樣如果在宣告陣列時我們並不清楚陣列的長度,就變的很棘手了。

針對於陣列的這些缺點,c#中最先提供了arraylist物件來克服這些缺點。

arraylist是.net framework提供的用於資料儲存和檢索的專用類,它是命名空間system.collections下的一部分。它的大小是按照其中儲存的資料來動態擴充與收縮的。所以,我們在宣告arraylist物件時並不需要指定它的長度。

arraylist繼承了ilist介面,所以它可以很方便的進行資料的新增,插入和移除.比如:

arraylist list = new

arraylist();

//新增資料

list.add("

abc"

);list.add(

123);

//修改資料

list[2] = 345;//

移除資料

list.removeat(0

);//

插入資料

list.insert(0, "

hello world

");

從上面示例看,arraylist好像是解決了陣列中所有的缺點,那麼它應該就是完美的了,為什麼在c#2.0後又會出現list呢?

還是從上面的示例看,在list中,我們不僅插入了字串"abc",而且又插入了數字123。這樣在arraylist中插入不同型別的資料是允許的。因為arraylist會把所有插入其中的資料都當作為object型別來處理。這樣,在我們使用arraylist中的資料來處理問題的時候,很可能會報型別不匹配的錯誤,也就是說arraylist不是型別安全的。既使我們保證在插入資料的時候都很小心,都有插入了同一型別的資料,但在使用的時候,我們也需要將它們轉化為對應的原型別來處理。這就存在了裝箱與拆箱的操作,會帶來很大的效能損耗。

穿插一下裝箱與拆箱的概念:

簡單的來講:

裝箱:就是將值型別的資料打包到引用型別的例項中

比如將int型別的值123賦給object物件o

int i=123

;object o=(object)i;

拆箱:就是從引用資料中提取值型別

比如將object物件o的值賦給int型別的變數i

object o=123

;int i=(int)o;

裝箱與拆箱的過程是很損耗效能的。

正是因為arraylist存在不安全型別與裝箱拆箱的缺點,所以在c#2.0後出現了泛型的概念。而list類是arraylist類的泛型等效類。它的大部分用法都與arraylist相似,因為list類也繼承了ilist介面。最關鍵的區別在於,在宣告list集合時,我們同時需要為其宣告list集合內資料的物件型別。

比如:

list list = new list();

//新增資料

list.add(123

);//

修改資料

list[0] = 345;//

移除資料

list.removeat(0);

上例中,如果我們往list集合中插入string字元"hello world",ide就會報錯,且不能通過編譯。這樣就避免了前面講的型別安全問題與裝箱拆箱的效能問題了。

陣列的容量是固定的,您只能一次獲取或設定乙個元素的值,而arraylist或list的容量可根據需要自動擴充、修改、刪除或插入資料。

陣列可以具有多個維度,而 arraylist或 list< t> 始終只具有乙個維度。但是,您可以輕鬆建立陣列列表或列表的列表。特定型別(object 除外)的陣列 的效能優於 arraylist的效能。 這是因為 arraylist的元素屬於 object 型別;所以在儲存或檢索值型別時通常發生裝箱和取消裝箱操作。不過,在不需要重新分配時(即最初的容量十分接近列表的最大容量),list< t> 的效能與同型別的陣列十分相近。

在決定使用 list還是使用arraylist 類(兩者具有類似的功能)時,記住list類在大多數情況下執行得更好並且是型別安全的。如果對list< t> 類的型別t 使用引用型別,則兩個類的行為是完全相同的。但是,如果對型別t使用值型別,則需要考慮實現和裝箱問題。

C 中的動態陣列ArrayList

arraylist就是實現了ilist,icollection,ienumerable,icloneable這幾個介面的動態陣列。即使.netframwork提供了一些更耐用更受歡迎的新的類,arraylist仍然十分有用。下面是一些在c 中使用arraylist的例項,一起看看其基本用法和一些高階...

C 中陣列 ArrayList和List三者的區別

在c 中陣列,arraylist,list都能夠儲存一組物件,那麼這三者到底有什麼樣的區別呢。陣列在c 中最早出現的。在記憶體中是連續儲存的,所以它的索引速度非常快,而且賦值與修改元素也很簡單。csharp view plain copy 陣列 string s new string 2 賦值 s ...

C 中陣列 ArrayList和List三者的區別

在c 中陣列,arraylist,list都能夠儲存一組物件,那麼這三者到底有什麼樣的區別呢。陣列在c 中最早出現的。在記憶體中是連續儲存的,所以它的索引速度非常快,而且賦值與修改元素也很簡單。csharp view plain copy font family simsun font size 1...