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

2022-07-03 12:15:06 字數 6334 閱讀 7119

1樓:我想問個清楚

陣列陣列在c#中最早出現的。在記憶體中是連續儲存的,所以它的索引速度非常快,而且賦值與修改元素也很簡單。

[csharp] view plaincopy

//陣列

string s=new string[2];

//賦值

s[0]="a";

s[1]="b";

//修改

s[1]="a1";

但是陣列存在一些不足的地方。在陣列的兩個資料間插入資料是很麻煩的,而且在宣告陣列的時候必須指定陣列的長度,陣列的長度過長,會造成記憶體浪費,過段會造成資料溢位的錯誤。如果在宣告陣列時我們不清楚陣列的長度,就會變得很麻煩。

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

arraylist

arraylist是名稱空間system.collections下的一部分,在使用該類時必須進行引用,同時繼承了ilist介面,提供了資料儲存和檢索。arraylist物件的大小是按照其中儲存的資料來動態擴充與收縮的。

所以,在宣告arraylist物件時並不需要指定它的長度。

[csharp] view plaincopy

//arraylist

arraylist list1 = new arraylist();

//新增資料

list1.add("cde");

list1.add(5678);

//修改資料

list[2] = 34;

//移除資料

list.removeat(0);

//插入資料

list.insert(0, "qwe");

從上面例子看,arraylist好像是解決了陣列中所有的缺點,為什麼又會有list?

我們從上面的例子看,在list中,我們不僅插入了字串cde,而且插入了數字5678。這樣在arraylist中插入不同型別的資料是允許的。因為arraylist會把所有插入其中的資料當作為object型別來處理,在我們使用arraylist處理資料時,很可能會報型別不匹配的錯誤,也就是arraylist不是型別安全的。

在儲存或檢索值型別時通常發生裝箱和取消裝箱操作,帶來很大的效能耗損。

裝箱與拆箱的概念:

簡單的說:

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

比如將string型別的值abc賦給object物件obj

[csharp] view plaincopy

string i=」abc」;

object obj=(object)i;

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

比如將object物件obj的值賦給string型別的變數i

[csharp] view plaincopy

object obj=」abc」;

string i=(string)obj;

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

泛型list

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

比如:[csharp] view plaincopy

listlist = new list();

//新增資料

list.add(「abc」);

//修改資料

list[0] = 「def」;

//移除資料

list.removeat(0);

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

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

陣列可以具有多個維度,而 arraylist或 list< t> 始終只具有一個維度。但是,您可以輕鬆建立陣列列表或列表的列表。特定型別(object 除外)的陣列 的效能優於 arraylist的效能。

這是因為 arraylist的元素屬於 object 型別;所以在儲存或檢索值型別時通常發生裝箱和取消裝箱操作。不過,在不需要重新分配時(即最初的容量十分接近列表的最大容量),list< t> 的效能與同型別的陣列十分相近。

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

2樓:匿名使用者

arraylist非泛型,因此可以add不同型別,但是陣列和list需要指定型別。

陣列和list在c#中最大的不同在於陣列需要指定大小而list不需要,當然遍歷的一些方法也不一樣。

3樓:匿名使用者

總結:陣列:多維,記憶體分配在棧上,大小受棧大小限制,連續儲存,索引速度快,修改麻煩,大小確定

arraylist:一維,長度不限,大小動態的,可以儲存任意資料型別,涉及裝箱拆箱,效能低

list: 一維,強型別泛型陣列,型別安全

c#中陣列,arraylist和list三者的區別

4樓:明槐宸

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

陣列可以具有多個維度,而 arraylist或 list< t> 始終只具有一個維度。但是,您可以輕鬆建立陣列列表或列表的列表。特定型別(object 除外)的陣列 的效能優於 arraylist的效能。

這是因為 arraylist的元素屬於 object 型別;所以在儲存或檢索值型別時通常發生裝箱和取消裝箱操作。不過,在不需要重新分配時(即最初的容量十分接近列表的最大容量),list< t> 的效能與同型別的陣列十分相近。

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

詳解可檢視

c#中陣列,arraylist和list三者的區別

5樓:

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

陣列可以具有多個維度,而 arraylist或 list< t> 始終只具有一個維度。但是,您可以輕鬆建立陣列列表或列表的列表。特定型別(object 除外)的陣列 的效能優於 arraylist的效能。

這是因為 arraylist的元素屬於 object 型別;所以在儲存或檢索值型別時通常發生裝箱和取消裝箱操作。不過,在不需要重新分配時(即最初的容量十分接近列表的最大容量),list< t> 的效能與同型別的陣列十分相近。

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

詳解可檢視

6樓:**最大功能

陣列長度是固定的、在定義時就固定了。

arraylist和list是集合,可以理解成長度可變的陣列,隨時可增減元素。

其中list只能放同一型別的元素。arraylist可以同時混著放多種型別的元素

比如listli=new list();

arraylist li = new arraylist() ;

7樓:匿名使用者

陣列陣列在c#中最早出現的。在記憶體中是連續儲存的,所以它的索引速度非常快,而且賦值與修改元素也很簡單。

[csharp] view plain copy

//陣列

string s=new string[2];

//賦值

s[0]="a";

s[1]="b";

//修改

s[1]="a1";

但是陣列存在一些不足的地方。在陣列的兩個資料間插入資料是很麻煩的,而且在宣告陣列的時候必須指定陣列的長度,陣列的長度過長,會造成記憶體浪費,過段會造成資料溢位的錯誤。如果在宣告陣列時我們不清楚陣列的長度,就會變得很麻煩。

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

arraylist

arraylist是名稱空間system.collections下的一部分,在使用該類時必須進行引用,同時繼承了ilist介面,提供了資料儲存和檢索。arraylist物件的大小是按照其中儲存的資料來動態擴充與收縮的。

所以,在宣告arraylist物件時並不需要指定它的長度。

//arraylist

arraylist list1 = new arraylist();

//新增資料

list1.add("cde");

list1.add(5678);

//修改資料

list[2] = 34;

//移除資料

list.removeat(0);

//插入資料

list.insert(0, "qwe");

從上面例子看,arraylist好像是解決了陣列中所有的缺點,為什麼又會有list?

從上面的例子看,在list中,不僅插入了字串cde,而且插入了數字5678。這樣在arraylist中插入不同型別的資料是允許的。因為arraylist會把所有插入其中的資料當作為object型別來處理,在使用arraylist處理資料時,很可能會報型別不匹配的錯誤,也就是arraylist不是型別安全的。

在儲存或檢索值型別時通常發生裝箱和取消裝箱操作,帶來很大的效能耗損。

裝箱與拆箱的概念:

簡單的說:

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

比如將string型別的值abc賦給object物件obj

[csharp] view plain copy

string i=」abc」;

object obj=(object)i;

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

比如將object物件obj的值賦給string型別的變數i

object obj=」abc」;

string i=(string)obj;

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

泛型list

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

比如:listlist = new list();

//新增資料

list.add(「abc」);

//修改資料

list[0] = 「def」;

//移除資料

list.removeat(0);

上例中,如果往list集合中插入int陣列123,ide就會報錯,且不能通過編譯。這樣就避免了前面講的型別安全問題與裝箱拆箱的效能問題了。

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

陣列可以具有多個維度,而 arraylist或 list< t> 始終只具有一個維度。但是,可以輕鬆建立陣列列表或列表的列表。特定型別(object 除外)的陣列 的效能優於 arraylist的效能。

這是因為 arraylist的元素屬於 object 型別;所以在儲存或檢索值型別時通常發生裝箱和取消裝箱操作。不過,在不需要重新分配時(即最初的容量十分接近列表的最大容量),list< t> 的效能與同型別的陣列十分相近。

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

C語言陣列中的刪除元素怎麼寫,C語言陣列中的刪除一個元素怎麼寫

直接把元素後一位覆蓋前一位就行了 最後把陣列最後一位清空即可 include main c語言中怎麼刪除陣列中的一個元素 方法 刪除就是將其下 copy標所在位置的中的內容置為空 也就是0 然後從此位置開始,後面的內容前移,再把最後那個位置的置為空 就是0 前移無非就是 類似 arr i 1 arr...

c 指標陣列問題,C 中關於指標陣列的問題。

是錯誤的。char cchar count 宣告瞭cchar是有count個元素的陣列,每個元素都是指向char型變數的指標。但cin cchar i 卻試圖給cchar的第二個元素 指標 賦一個鍵盤值 這裡指標還沒有確定指向,是隨機的,它隨機地指向了不能寫入的地方,就要出錯。這裡應該先給指標陣列賦...

c符陣列和字元指標,C 字元陣列和字元指標

你這個問題問得很好,我們知道實際上一個字串在進行賦值的時候,例如 char p hello world 這樣賦值是允許的。那麼這並不代表 hello world 這個就是一個指標,實際上我們的這一動作,編譯器在幕後為我們做了很多事,首先在常量區分配一個字元陣列,然後將 hello world 這個字...