C#中Linq延遲查詢的例子
提出問(wèn)題
下面所給代碼編譯時(shí)正常,但是執(zhí)行時(shí)會(huì)出錯(cuò),請(qǐng)指出程序在執(zhí)行時(shí)能夠執(zhí)行到編號(hào)為(1)(2)(3)的代碼行中的哪一行。
using System; using System.Collections.Generic; using System.Linq; namespace DeferredExecutionExp { class Program { static void Main(string[] args) { List<Student> studentList = new List<Student>() { new Student(){Id =1, Name="ZhangSan", Age=20}, new Student(){Id =2, Name=null, Age=21}, new Student(){Id =3, Name="Lisi", Age=22} }; var queryedStudentList = studentList.Where(it => it.Name.Trim() != "ZhangSan");//(1) if (queryedStudentList.Count() > 0)//(2) { foreach (var student in queryedStudentList)//(3) { Console.WriteLine(student.Name); } } } } public class Student { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } }
問(wèn)題分析
其實(shí),發(fā)現(xiàn)問(wèn)題并不難,很顯然在執(zhí)行代碼“it => it.Name.Trim()”時(shí)會(huì)出錯(cuò),因?yàn)榧蟬tudentList中第二個(gè)學(xué)生的Name屬性為null,當(dāng)遍歷到該學(xué)生時(shí),對(duì)其Name屬性執(zhí)行Trim操作,不出錯(cuò)才怪呢。既然在這里會(huì)出錯(cuò),那么程序肯定是執(zhí)行到該行就GameOver了呀。但是實(shí)際情況又會(huì)是這樣嗎?
動(dòng)手驗(yàn)證
單步調(diào)試程序,發(fā)現(xiàn):執(zhí)行到代碼行(1)時(shí),程序并沒(méi)有出錯(cuò),而是在執(zhí)行代碼行(2)時(shí),程序才出現(xiàn)了異常,查看異常信息,卻提示的是在執(zhí)行代碼行(1)時(shí)有問(wèn)題,為什么會(huì)這樣呢?為什么執(zhí)行到代碼行(2)時(shí)還會(huì)去執(zhí)行代碼行(1)呢?這全都是因?yàn)長(zhǎng)inq的延遲查詢導(dǎo)致的。
延遲查詢
延遲查詢的意思是說(shuō):在運(yùn)行期間定義查詢表達(dá)式時(shí),查詢不會(huì)執(zhí)行,只有到迭代數(shù)據(jù)項(xiàng)時(shí)查詢才會(huì)被執(zhí)行。本例中的代碼行(1)只是定義了查詢,而代碼行(2)中當(dāng)調(diào)用Count方法時(shí)便會(huì)遍歷數(shù)據(jù)項(xiàng),這時(shí)便會(huì)執(zhí)行查詢,也就是說(shuō)會(huì)去執(zhí)行代碼行(1)定義的查詢,最終導(dǎo)致了本例中這種現(xiàn)象的出現(xiàn)。
所以,本例中的代碼最終能夠執(zhí)行到的代碼行是(2)。
- C#集合查詢Linq在項(xiàng)目中使用詳解
- C# Linq延遲查詢的執(zhí)行實(shí)例代碼
- c# Linq查詢?cè)斀?/a>
- c# 動(dòng)態(tài)構(gòu)建LINQ查詢表達(dá)式
- C#使用LINQ查詢表達(dá)式的基本子句總結(jié)
- C# linq查詢之動(dòng)態(tài)OrderBy用法實(shí)例
- C#使用linq語(yǔ)句查詢數(shù)組中以特定字符開(kāi)頭元素的方法
- C#使用linq查詢大數(shù)據(jù)集的方法
- C#中Linq查詢基本操作使用實(shí)例
- C# LINQ查詢表達(dá)式及對(duì)應(yīng)LAMBDA表達(dá)式的用法
- C#使用LINQ查詢操作符實(shí)例代碼(一)
相關(guān)文章
WPF使用Dragablz構(gòu)建可拖拽分離的Tab頁(yè)程序
這篇文章介紹了WPF使用Dragablz構(gòu)建可拖拽分離Tab頁(yè)的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06動(dòng)態(tài)改變gridview列寬度函數(shù)分享
通常用GridView綁定datatable,由于需要?jiǎng)討B(tài)綁定到不同的datatable所以需要?jiǎng)討B(tài)調(diào)整GridView的寬度。寫了這個(gè)函數(shù)實(shí)現(xiàn)該功能2014-01-01解決C#運(yùn)行程序修改數(shù)據(jù)后數(shù)據(jù)表不做更新的問(wèn)題
近日,在使用C#連接數(shù)據(jù)庫(kù)的時(shí)候,對(duì)數(shù)據(jù)庫(kù)中的表做更新后,在當(dāng)前啟動(dòng)項(xiàng)目中去顯示表數(shù)據(jù)時(shí)雖然會(huì)發(fā)生一個(gè)更新,但是在結(jié)束程序運(yùn)行后再去觀察數(shù)據(jù)表中的記錄時(shí)發(fā)現(xiàn)并沒(méi)有發(fā)生一個(gè)變化,所以本文給大家解決一下這個(gè)問(wèn)題,需要的朋友可以參考下2023-08-08C#程序(含多個(gè)Dll)合并成一個(gè)Exe的簡(jiǎn)單方法
這篇文章主要為大家詳細(xì)介紹了C#程序(含多個(gè)Dll)合并成一個(gè)Exe的簡(jiǎn)單方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12C# Onnx CenterNet實(shí)現(xiàn)目標(biāo)檢測(cè)的示例詳解
這篇文章主要為大家詳細(xì)介紹了C# Onnx CenterNet實(shí)現(xiàn)目標(biāo)檢測(cè)的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12