淺談C#中的集合對(duì)象(Collections)
記得教科書上有這樣一句話:"如果需要使用同一類型的多個(gè)對(duì)象,就可以使用集合和數(shù)組。" ,是的,沒有錯(cuò).只是數(shù)組的大小是固定的。如果元素個(gè)數(shù)是動(dòng)態(tài)的,就應(yīng)使用集合類。在.NET Framework里,集合有很多,如List
1.數(shù)組
在實(shí)際應(yīng)用中,數(shù)組又可分為:簡(jiǎn)單數(shù)組、多維數(shù)組、鋸齒數(shù)組、Array數(shù)組.使用最多的應(yīng)該算的簡(jiǎn)單數(shù)組和多維數(shù)組,這里我以簡(jiǎn)單數(shù)組為例簡(jiǎn)單介紹下數(shù)組的簡(jiǎn)單使用,關(guān)于的其他知識(shí)點(diǎn)請(qǐng)大家參考相關(guān)資料和書籍.
比如說我們要定義一個(gè)整型的簡(jiǎn)單數(shù)組,那應(yīng)該怎么定義呢?
classProgram |
是上面這樣定義和使用的嗎?我想稍微學(xué)過編程的朋友都可以給出肯定的答案.關(guān)于這點(diǎn)我不想作過多的解釋.見下圖:
這里我們是使用的基本類型(int)類型來定義的數(shù)組,在使用開發(fā)中我們還會(huì)使用到自定義類型數(shù)組,下面我就簡(jiǎn)單的說說這方面的知識(shí).要定義自定義類型數(shù)組,那么首先就應(yīng)該有個(gè)自定義類型,當(dāng)然這個(gè)類型可以封其他的相關(guān)屬性.OK,如下代碼段:
/// |
如上就是一個(gè)自定義的類型,我們?cè)谄鋬?nèi)部封裝了一個(gè)name屬性.那么,類型已經(jīng)定義好,那我們應(yīng)該如何去使用這個(gè)自定義類型去定義一個(gè)數(shù)組呢?是這樣的嗎?
classProgram |
如上我們就完成了一個(gè)自定義類型的對(duì)象數(shù)組的定義,以及數(shù)組的相關(guān)操作.見下圖:
由于多維數(shù)組、鋸齒數(shù)組、Array數(shù)組等數(shù)組在實(shí)際的開發(fā)中使用不是很多,這里就不作介紹.
2.集合對(duì)象
集合類可以組合為集合,存儲(chǔ)Object類型的元素和泛型集合類。在.NET 2.0之前,不存在泛型?,F(xiàn)在泛型集合類通常是集合的首選類型。泛型集合類是類型安全的,如果使用值類型,是不需要裝箱操作的。如果要在集合中添加不同類型的對(duì)象,且這些對(duì)象不是相互派生的,例如在集合中添加int和string對(duì)象,就只需基于對(duì)象的集合類。
象類型的集合位于System.Collections命名空間;泛型集合類位于System.Collections. Generic命名空間;當(dāng)然,組合集合類還有其他方式。集合可以根據(jù)集合類執(zhí)行的接口組合為列表、集合和字典。接口及其功能如表10-1所示。.NET 2.0為集合類添加了新的泛型接口,例如IEnumerable
(1)列表
.NET Framework為動(dòng)態(tài)列表提供了類ArrayList和List
classProgram
{
staticvoidMain(string[]args)
{
//創(chuàng)建列表
ArrayListlist=newArrayList();
//添加元素
list.Add("張三");
//插入元素
list.Insert(1,"李四");
//訪問元素
stringname=list[0].ToString();
//刪除元素
list.RemoveAt(1);//刪除索引號(hào)為1的元素|Remove(Objectobj);
//檢索元素
intindex=list.IndexOf("張三"); //得到對(duì)象所在的下標(biāo)
//排序元素
list.Sort(); //有多種重載
Listl=newList (); //創(chuàng)建列表
l.Add(1); //添加元素
l.Add(7);
l.Add(3);
l.Add(9);
l.Add(6);
l.Add(10);
l.Sort();
foreach(int iinl)
{
Console.Write(i+"");
}
l.Remove(10); //刪除值為10的元素
}
}
關(guān)于列表的算法可以參考我以前寫過的一篇文章,文章連接:列表算法
(2)隊(duì)列
隊(duì)列是其元素以先進(jìn)先出(FIFO)的方式來處理的集合。先放在隊(duì)列中的元素會(huì)先讀取??山Y(jié)合下圖來理解:
在.NET的System.Collections命名空間中有非泛型類Queue,在System.Collections. Generic命名空間中有泛型類Queue
在創(chuàng)建隊(duì)列時(shí),可以使用與List
不過一般項(xiàng)目中用得不是很多,這里故不做示例代碼.
【編輯推薦】