日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
LINQ子查詢和延遲執(zhí)行編程實(shí)例

很多朋友對(duì)LINQ子查詢和延遲執(zhí)行的用法還不是很明了,下面就通過(guò)一個(gè)實(shí)例來(lái)給大家展示LINQ子查詢的相關(guān)用法。

廊坊網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)于2013年創(chuàng)立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。

LINQ子查詢

LINQ子查詢是一個(gè)包含了另外一個(gè)查詢的Lambda表達(dá)式的查詢. 以下的例子使用了一個(gè)LINQ子查詢來(lái)針對(duì)籃球明星的last name排序:

 
 
 
  1. string[] players = { "Tim Ducan""Lebrom James""Kobe Byrant" };   
  2. IEnumerable<string> q = players.OrderBy (m => m.Split().Last()); 

在這其中, Last是一個(gè)LINQ子查詢, q則代表了一個(gè)外部查詢.

在LINQ子查詢中, 你可以在Lambda表達(dá)式的右邊使用任何可行的C#表達(dá)語(yǔ)法.LINQ 子查詢只是一個(gè)簡(jiǎn)單的C#表達(dá)式, 這意味著所有適用于LINQ子查詢的規(guī)則都可以推導(dǎo)到Lambda表達(dá)式上.

以下的查詢?nèi)〉靡粋€(gè)字符數(shù)組中所有滿足長(zhǎng)度等于最小長(zhǎng)度的字符序列:

 
 
 
  1. string[] names = { "James","Jack","Landy","C.Y","Jay" };     
  2. IEnumerable<string> q = names     
  3.   .Where (n => n.Length ==     
  4.      names.OrderBy (n2 => n2.Length)     
  5.           .Select  (n2 => n2.Length).First( )     
  6.   );     
  7. foreach(var s in q)     
  8. {     
  9.     Console.WriteLine(s); //C.Y , Jay    

對(duì)于LINQ子查詢, 可以引用到外部的Lambda參數(shù)或者是迭代變量(在復(fù)合查詢中). 例如上述的例子中, 如果OrderBy使用的表達(dá)式改為(n => n.Length)而不是用n2的話將會(huì)得到一個(gè)錯(cuò)誤信息:

A local variable named ‘n’ cannot be declared in this scope because it would give a different meaning to ‘n’, which is already used in a ‘parent or current’ scope to denote something else.

針對(duì)這個(gè)例子, 我們可以看到對(duì)應(yīng)的復(fù)合查詢寫法:

 
 
 
  1. IEnumerable<string> q =     
  2.   from n in names     
  3.   where n.Length ==     
  4.     (from n2 in names     
  5.      orderby n2.Length     
  6.      select n2.Length).First( )     
  7.   select n; 

外部迭代變量n在LINQ子查詢范圍內(nèi)是可見的, 因此我們不能將它重用為L(zhǎng)INQ子查詢內(nèi)部的迭代變量.

LINQ子查詢會(huì)在對(duì)應(yīng)的Lambda表達(dá)式被執(zhí)行的時(shí)候來(lái)執(zhí)行, 其執(zhí)行取決于外部查詢, 也可以說(shuō)是由外到里來(lái)處理的. 本地查詢完全遵循這個(gè)模型, 但是解釋型查詢(例如LINQ to SQL)則僅僅是概念上遵循而已.

之前的查詢我們還可以使用一種更加簡(jiǎn)潔的寫法:

 
 
 
  1. IEnumerable<string> q =     
  2.   from n in names     
  3.   where  n.Length ==     
  4.          names.OrderBy (n2 => n2.Length).First().Length     
  5.   select n; 

如果使用Min聚合函數(shù), 還可以進(jìn)一步簡(jiǎn)化:

 
 
 
  1. IEnumerable<string> q =     
  2.       from n in names     
  3.       where n.Length == names.Min (n2 => n2.Length)     
  4.       select n; 

實(shí)際上, 由于n2.Length在外部查詢循環(huán)的時(shí)候每次都會(huì)重新計(jì)算, 這在某些情況下可能會(huì)引起效率問(wèn)題, 避免這個(gè)問(wèn)題, 我們可以將LINQ子查詢分離出來(lái):

 
 
 
  1. int len = names.Min (n => n.Length);     
  2.       
  3. IEnumerable<string> query = from   n in names     
  4.                             where  n.Length == len     
  5.                             select n; 

子查詢和延遲執(zhí)行

在LINQ子查詢中的返回單一元素或者聚合類操作符, 例如first或者Count, 并不會(huì)強(qiáng)制外部查詢立即執(zhí)行, 也就說(shuō)外部查詢依然擁有延遲執(zhí)行的能力. 這是因?yàn)長(zhǎng)INQ子查詢是被間接調(diào)用的 – 如果是本地查詢則是通過(guò)代理(delegate), 如果是解釋性查詢則是通過(guò)表達(dá)樹(expression tree).

一個(gè)有趣的現(xiàn)象是當(dāng)你的LINQ子查詢中包含一個(gè)Select表達(dá)式的時(shí)候, 如果是本地查詢, 你實(shí)際上是將其發(fā)散成一序列的查詢 – 并且每一個(gè)都擁有延遲執(zhí)行的能力. 這個(gè)影響是透明的, 因?yàn)樗梢燥@著提高效率.

【編輯推薦】

  1. LINQ——語(yǔ)言級(jí)集成查詢?nèi)腴T指南
  2. LINQ查詢的目的與實(shí)現(xiàn)手段
  3. 實(shí)例二:綁定到LINQ查詢的結(jié)果
  4. LINQ查詢表達(dá)式深入剖析
  5. LINQ的演變及其對(duì)C#設(shè)計(jì)的影響

網(wǎng)頁(yè)名稱:LINQ子查詢和延遲執(zhí)行編程實(shí)例
文章地址:http://www.5511xx.com/article/coheddo.html