




已閱讀5頁,還剩3頁未讀, 繼續(xù)免費閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
C# List用法所屬命名空間:System.Collections.Generic public class List : IList, ICollection, IEnumerable, IList, ICollection, IEnumerable List類是 ArrayList 類的泛型等效類。該類使用大小可按需動態(tài)增加的數(shù)組實現(xiàn) IList 泛型接口。 泛型的好處: 它為使用c#語言編寫面向?qū)ο蟪绦蛟黾恿藰O大的效力和靈活性。不會強(qiáng)行對值類型進(jìn)行裝箱和拆箱,或?qū)σ妙愋瓦M(jìn)行向下強(qiáng)制類型轉(zhuǎn)換,所以性能得到提高。性能注意事項:在決定使用IList 還是使用ArrayList類(兩者具有類似的功能)時,記住IList 類在大多數(shù)情況下執(zhí)行得更好并且是類型安全的。如果對IList 類的類型 T 使用引用類型,則兩個類的行為是完全相同的。但是,如果對類型 T 使用值類型,則需要考慮實現(xiàn)和裝箱問題。 用微軟的話講:“添加到 ArrayList 中的任何引用或值類型都將隱式地向上強(qiáng)制轉(zhuǎn)換為 Object。如果項是值類型,則必須在將其添加到列表中時進(jìn)行裝箱操作,在檢索時進(jìn)行取消裝箱操作。強(qiáng)制轉(zhuǎn)換以及裝箱和取消裝箱操作都會降低性能;在必須對大型集合進(jìn)行循環(huán)訪問的情況下,裝箱和取消裝箱的影響非常明顯?!?、 List的基礎(chǔ)、常用方法:聲明:1、List mList = new List(); T為列表中元素類型,現(xiàn)在以string類型作為例子E.g.: List mList = new List();2、 List testList =new List (IEnumerable collection); 以一個集合作為參數(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) 添加一個元素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位置添加一個元素E.g.: mList.Insert(1, Hei);遍歷List中元素: foreach (T element in mList) T的類型與mList聲明時一樣 Console.WriteLine(element); E.g.:foreach (string s in mList) Console.WriteLine(s); 刪除元素: 1、 List. Remove(T item) 刪除一個值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開始,刪除count個元素 E.g.: mList.RemoveRange(3, 2);判斷某個元素是否在該List中:List. Contains(T item) 返回true或false,很實用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)是元素第一個字母按升序E.g.: mList.Sort();給List里面元素順序反轉(zhuǎn):List. Reverse () 可以與List. Sort ()配合使用,達(dá)到想要的效果E.g.: mList.Sort(); List清空:List. Clear ()E.g.: mList.Clear(); 獲得List中元素數(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 方法:搜索與指定謂詞所定義的條件相匹配的元素,并返回整個 List 中的第一個匹配元素。public T Find(Predicate match);Predicate是對方法的委托,如果傳遞給它的對象與委托中定義的條件匹配,則該方法返回 true。當(dāng)前 List 的元素被逐個傳遞給Predicate委托,并在 List 中向前移動,從第一個元素開始,到最后一個元素結(jié)束。當(dāng)找到匹配項時處理即停止。Predicate 可以委托給一個函數(shù)或者一個拉姆達(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委托給一個函數(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 方法:搜索與指定謂詞所定義的條件相匹配的元素,并返回整個 List 中的最后一個匹配元素。public T FindLast(Predicate match);用法與List.Find相同。List.TrueForAll方法: 確定是否 List 中的每個元素都與指定的謂詞所定義的條件相匹配。 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委托給一個函數(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); 這時subList存儲的就是所有長度大于3的元素List.Take(n): 獲得前n行 返回值為IEnumetable,T的類型與List的類型一樣E.g.:IEnumerable takeList= mList.Take(5); foreach (string s in takeList) Console.WriteLine(element in takeList: + s); 這時takeList存放的元素就是mList中的前5個List.Where方法:檢索與指定謂詞所定義的條件相匹配的所有元素。跟List.FindAll方法類似。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); 這時subList存儲的就是所有長度大于3的元素List.RemoveAll方法:移除與指定的謂詞所定義的條件相匹配的所有元素。public int
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年中國機(jī)翼型中空鋁合金葉輪數(shù)據(jù)監(jiān)測報告
- 2025-2030年中國三級綜合醫(yī)院行業(yè)市場運行調(diào)研與投資風(fēng)險研究報告
- 2025年中國新鈴蘭醛數(shù)據(jù)監(jiān)測報告
- 2025年中國數(shù)字音頻復(fù)接設(shè)備數(shù)據(jù)監(jiān)測研究報告
- 2025年中國爐具銅分火器數(shù)據(jù)監(jiān)測報告
- 肇慶市實驗中學(xué)高中生物三:2生長素的生理作用第2課時導(dǎo)學(xué)案
- 肇慶市實驗中學(xué)高中歷史三:第課音樂與美術(shù)高效課堂教學(xué)設(shè)計
- 新疆科信職業(yè)技術(shù)學(xué)院《人體解刨學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 新疆沙雅縣二中2025年高三三月模擬考試化學(xué)試題(文理)試卷含解析
- 新鄉(xiāng)工程學(xué)院《寫作思維學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 巨量引擎信息流廣告(初級)認(rèn)證理論試題庫資料(含答案)
- 建筑幕墻安裝工程安全施工施工工藝技術(shù)
- CJT 306-2009 建設(shè)事業(yè)非接觸式CPU卡芯片技術(shù)要求
- 情緒調(diào)節(jié)的認(rèn)知神經(jīng)機(jī)制
- 供貨方案及供貨計劃(2篇)
- 離散數(shù)學(xué)(下)智慧樹知到期末考試答案章節(jié)答案2024年桂林電子科技大學(xué)
- CATIA創(chuàng)成式曲面設(shè)計經(jīng)典收藏
- QC/T 922-2023 汽車用空氣濾清器濾芯 (正式版)
- 2024年高考政治必修二 《經(jīng)濟(jì)與社會》(思維導(dǎo)圖+核心考點+易混易錯)
- 個人借車免責(zé)協(xié)議書完整版
- 中華人民共和國突發(fā)事件應(yīng)對法課件
評論
0/150
提交評論