已閱讀5頁(yè),還剩3頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
C# List用法所屬命名空間:System.Collections.Generic public class List : IList, ICollection, IEnumerable, IList, ICollection, IEnumerable List類(lèi)是 ArrayList 類(lèi)的泛型等效類(lèi)。該類(lèi)使用大小可按需動(dòng)態(tài)增加的數(shù)組實(shí)現(xiàn) IList 泛型接口。 泛型的好處: 它為使用c#語(yǔ)言編寫(xiě)面向?qū)ο蟪绦蛟黾恿藰O大的效力和靈活性。不會(huì)強(qiáng)行對(duì)值類(lèi)型進(jìn)行裝箱和拆箱,或?qū)σ妙?lèi)型進(jìn)行向下強(qiáng)制類(lèi)型轉(zhuǎn)換,所以性能得到提高。性能注意事項(xiàng):在決定使用IList 還是使用ArrayList類(lèi)(兩者具有類(lèi)似的功能)時(shí),記住IList 類(lèi)在大多數(shù)情況下執(zhí)行得更好并且是類(lèi)型安全的。如果對(duì)IList 類(lèi)的類(lèi)型 T 使用引用類(lèi)型,則兩個(gè)類(lèi)的行為是完全相同的。但是,如果對(duì)類(lèi)型 T 使用值類(lèi)型,則需要考慮實(shí)現(xiàn)和裝箱問(wèn)題。 用微軟的話(huà)講:“添加到 ArrayList 中的任何引用或值類(lèi)型都將隱式地向上強(qiáng)制轉(zhuǎn)換為 Object。如果項(xiàng)是值類(lèi)型,則必須在將其添加到列表中時(shí)進(jìn)行裝箱操作,在檢索時(shí)進(jìn)行取消裝箱操作。強(qiáng)制轉(zhuǎn)換以及裝箱和取消裝箱操作都會(huì)降低性能;在必須對(duì)大型集合進(jìn)行循環(huán)訪問(wèn)的情況下,裝箱和取消裝箱的影響非常明顯?!?、 List的基礎(chǔ)、常用方法:聲明:1、List mList = new List(); T為列表中元素類(lèi)型,現(xiàn)在以string類(lèi)型作為例子E.g.: List mList = new List();2、 List testList =new List (IEnumerable collection); 以一個(gè)集合作為參數(shù)創(chuàng)建List E.g.:string temArr = Ha, Hunter, Tom, Lily, Jay, Jim, Kuku, Locu ;List testList = new List(temArr);添加元素: 1、 List. Add(T item) 添加一個(gè)元素E.g.: mList.Add(John);2、 List. AddRange(IEnumerable collection) 添加一組元素E.g.: string temArr = Ha,Hunter, Tom, Lily, Jay, Jim, Kuku, Locu ;mList.AddRange(temArr);3、Insert(int index, T item); 在index位置添加一個(gè)元素E.g.: mList.Insert(1, Hei);遍歷List中元素: foreach (T element in mList) T的類(lèi)型與mList聲明時(shí)一樣 Console.WriteLine(element); E.g.:foreach (string s in mList) Console.WriteLine(s); 刪除元素: 1、 List. Remove(T item) 刪除一個(gè)值E.g.: mList.Remove(Hunter); 2、 List. RemoveAt(int index); 刪除下標(biāo)為index的元素E.g.: mList.RemoveAt(0); 3、 List. RemoveRange(int index, int count); 從下標(biāo)index開(kāi)始,刪除count個(gè)元素 E.g.: mList.RemoveRange(3, 2);判斷某個(gè)元素是否在該List中:List. Contains(T item) 返回true或false,很實(shí)用E.g.:if (mList.Contains(Hunter) Console.WriteLine(There is Hunter in the list); else mList.Add(Hunter); Console.WriteLine(Add Hunter successfully.); 給List里面元素排序:List. Sort () 默認(rèn)是元素第一個(gè)字母按升序E.g.: mList.Sort();給List里面元素順序反轉(zhuǎn):List. Reverse () 可以與List. Sort ()配合使用,達(dá)到想要的效果E.g.: mList.Sort(); List清空:List. Clear ()E.g.: mList.Clear(); 獲得List中元素?cái)?shù)目:List. Count () 返回int值E.g.:int count = mList.Count(); Console.WriteLine(The num of elements in the list: +count);2、 List的進(jìn)階、強(qiáng)大方法:舉例用的List:string temArr = Ha,Hunter, Tom, Lily, Jay, Jim, Kuku, Locu ;mList.AddRange(temArr);List.Find 方法:搜索與指定謂詞所定義的條件相匹配的元素,并返回整個(gè) List 中的第一個(gè)匹配元素。public T Find(Predicate match);Predicate是對(duì)方法的委托,如果傳遞給它的對(duì)象與委托中定義的條件匹配,則該方法返回 true。當(dāng)前 List 的元素被逐個(gè)傳遞給Predicate委托,并在 List 中向前移動(dòng),從第一個(gè)元素開(kāi)始,到最后一個(gè)元素結(jié)束。當(dāng)找到匹配項(xiàng)時(shí)處理即停止。Predicate 可以委托給一個(gè)函數(shù)或者一個(gè)拉姆達(dá)表達(dá)式委托給拉姆達(dá)表達(dá)式:E.g.: string listFind = mList.Find(name = /name是變量,代表的是mList /中元素,自己設(shè)定 if (name.Length 3) return true; return false; ); Console.WriteLine(listFind); /輸出是Hunter委托給一個(gè)函數(shù):E.g.:string listFind1 = mList.Find(ListFind); /委托給ListFind函數(shù)Console.WriteLine(listFind); /輸出是HunterListFind函數(shù):public bool ListFind(string name) if (name.Length 3) return true; return false; 這兩種方法的結(jié)果是一樣的。List.FindLast 方法:搜索與指定謂詞所定義的條件相匹配的元素,并返回整個(gè) List 中的最后一個(gè)匹配元素。public T FindLast(Predicate match);用法與List.Find相同。List.TrueForAll方法: 確定是否 List 中的每個(gè)元素都與指定的謂詞所定義的條件相匹配。 public bool TrueForAll(Predicate match);委托給拉姆達(dá)表達(dá)式:E.g.: bool flag = mList.TrueForAll(name = if (name.Length 3) return true; else return false; ); Console.WriteLine(True for all: +flag); /flag值為false委托給一個(gè)函數(shù),這里用到上面的ListFind函數(shù):E.g.: bool flag = mList.TrueForAll(ListFind); /委托給ListFind函數(shù)Console.WriteLine(True for all: +flag); /flag值為false這兩種方法的結(jié)果是一樣的。List.FindAll方法:檢索與指定謂詞所定義的條件相匹配的所有元素。public List FindAll(Predicate match);E.g.:List subList = mList.FindAll(ListFind); /委托給ListFind函數(shù) foreach (string s in subList) Console.WriteLine(element in subList: +s); 這時(shí)subList存儲(chǔ)的就是所有長(zhǎng)度大于3的元素List.Take(n): 獲得前n行 返回值為IEnumetable,T的類(lèi)型與List的類(lèi)型一樣E.g.:IEnumerable takeList= mList.Take(5); foreach (string s in takeList) Console.WriteLine(element in takeList: + s); 這時(shí)takeList存放的元素就是mList中的前5個(gè)List.Where方法:檢索與指定謂詞所定義的條件相匹配的所有元素。跟List.FindAll方法類(lèi)似。E.g.: IEnumerable whereList = mList.Where(name = if (name.Length 3) return true; else return false; ); foreach (string s in subList) Console.WriteLine(element in subList: +s); 這時(shí)subList存儲(chǔ)的就是所有長(zhǎng)度大于3的元素List.RemoveAll方法:移除與指定的謂詞所定義的條件相匹配的所有元素。public int
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度老舊廠房拆除重建項(xiàng)目轉(zhuǎn)讓合同3篇
- 二零二五版UPS不間斷電源系統(tǒng)在數(shù)據(jù)中心節(jié)能改造中的應(yīng)用合同3篇
- 二零二五年度食品安全樣本檢驗(yàn)合同2篇
- 2025年度物業(yè)管理委托合同(住宅小區(qū))3篇
- 二零二五版公司銷(xiāo)售業(yè)務(wù)員合同協(xié)議書(shū)含虛擬貨幣交易業(yè)務(wù)合作3篇
- 2024煙花爆竹行業(yè)信用風(fēng)險(xiǎn)防范購(gòu)銷(xiāo)合同管理3篇
- 二零二五版廠房轉(zhuǎn)租及物業(yè)管理合同6篇
- 2024版電梯安全管理協(xié)議范本
- 二零二五年度橋梁隧道施工監(jiān)控安裝合同2篇
- 2025年度船舶環(huán)保技術(shù)改造項(xiàng)目股份合作協(xié)議3篇
- 2025年山東光明電力服務(wù)公司招聘筆試參考題庫(kù)含答案解析
- 《神經(jīng)發(fā)展障礙 兒童社交溝通障礙康復(fù)規(guī)范》
- 詩(shī)詞接龍(飛花令)PPT
- 子宮內(nèi)膜癌(課堂PPT)
- 澳大利亞公司法1-30
- 海上試油測(cè)試技術(shù)0327
- 中國(guó)地圖標(biāo)準(zhǔn)版(可編輯顏色)
- 瑪氏銷(xiāo)售常用術(shù)語(yǔ)中英對(duì)照
- (完整)貓咪上門(mén)喂養(yǎng)服務(wù)協(xié)議書(shū)
- 上海牛津版三年級(jí)英語(yǔ)3B期末試卷及答案(共5頁(yè))
- 行為疼痛量表BPS
評(píng)論
0/150
提交評(píng)論