偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

技巧:LINQ組合查詢?nèi)绾魏喕幊?/h1>

開發(fā) 后端
本文介紹了通過linq組合查詢來簡化代碼編寫的7個(gè)技巧,非常實(shí)用。

如何通過linq組合查詢來簡化代碼編寫?很多朋友可能都想過問題。下面,就給大家介紹一下我對于linq組合查詢的一些使用心得。

自從學(xué)習(xí)linq以來,我發(fā)現(xiàn)了很多使用linq組合查詢來改善代碼的方式。每一個(gè)技巧都讓代碼寫起來更簡單,可讀性更強(qiáng)。

這里總結(jié)了這些技巧。我會介紹如何使用linq組合查詢來:

◆初始化數(shù)組

◆在一個(gè)循環(huán)中遍歷多個(gè)數(shù)組

◆生成隨機(jī)序列

◆生成字符串

◆轉(zhuǎn)換序列或集合

◆把值轉(zhuǎn)換為長度為1的序列

◆遍歷序列的所有子集

如果你在linq組合查詢方面有心得也歡迎在評論中一起分享。

1. 初始化數(shù)組

通常,我們需要把數(shù)組的值初始化為相同的值或遞增的序列值,或者可能是一個(gè)步進(jìn)不為1的遞增/遞減序列。有了linq組合查詢,我們可以在數(shù)組的初始化器中完成所有工作,不再需要循環(huán)!

在如下的示例代碼中,***行代碼初始化了一個(gè)長度為10的數(shù)組,所有元素都是-1,第二行代碼初始化b為0、1、2到9,第三行代碼初始化c為100、110、120到190。

  1. int[] a = enumerable.repeat(-1, 10).toarray();  
  2.  
  3. int[] b = enumerable.range(0, 10).toarray();  
  4.  
  5. int[] c = enumerable.range(0, 10).select(i => 100 + 10 * i).toarray(); 

要提醒一下:如果你初始化一個(gè)很大的數(shù)組,***不考慮這種優(yōu)雅的方式而是使用傳統(tǒng)的方式來替代。linq組合查詢的這種解決方案會動態(tài)產(chǎn)生數(shù)組,因此垃圾數(shù)組需要在運(yùn)行時(shí)被回收。也就是說,我總是會在小數(shù)組或測試調(diào)試代碼的情況下使用這種技巧。

2. 在一個(gè)循環(huán)中遍歷多個(gè)數(shù)組

有個(gè)朋友問我一個(gè)C#的問題:有沒有辦法在一個(gè)循環(huán)中遍歷多個(gè)集合?他的代碼差不多是這樣:

  1. foreach (var x in array1) {  
  2.  
  3.     dosomething(x);  
  4. }   
  5.  
  6. foreach (var x in array2) {  
  7.  
  8.     dosomething(x);  

這樣的話,循環(huán)主體會很大,而且他也不希望這樣重復(fù)的代碼。但是,他又不希望創(chuàng)建一個(gè)數(shù)組來保存array1和array2的所有元素。

linq組合查詢提供了一種優(yōu)雅的解決方案:concat操作。我們可以使用單個(gè)循環(huán)來重寫上面的代碼,如下:

  1. foreach (var x in array1.concat(array2)) {  
  2.  
  3.     dosomething(x);  
  4.  

注意,由于linq組合查詢在枚舉器級別進(jìn)行操作,他不會產(chǎn)生新的數(shù)組來保存array1和array2的元素。因此,除了優(yōu)雅之外,這個(gè)方案還很高效。

3. 生成隨機(jī)序列

這是一個(gè)生成n長度隨機(jī)序列的簡單技巧:

  1. random rand = new random();  
  2.  
  3. var randomseq = enumerable.repeat(0, n).select(i => rand.next()); 

有了linq組合查詢的延遲特性,序列不會實(shí)現(xiàn)進(jìn)行計(jì)算并保存到數(shù)組中,而是在迭代randomseq的時(shí)候按需生成隨機(jī)數(shù)。

4. 生成字符串

linq組合查詢同樣也是生成各種類型字符串的好工具。對于測試或調(diào)試,生成字符串時(shí)很有用的。假設(shè)我們需要生成一個(gè)n長度的字符串,按照“abcabcabc”的方式。使用linq組合查詢,解決方案非常優(yōu)雅:

  1. string str = new string(  
  2.  
  3.     enumerable.range(0, n)  
  4.  
  5.     .select(i => (char)(‘a(chǎn)’ + i % 3))  
  6.  
  7.     .toarray()); 

petar petrov給出了另外一種有趣的方式使用linq組合查詢來生成字符串:

  1. string values = string.join(string.empty,   
  2. enumerable.repeat(pattern, n).toarray()); 

#p#

5. 轉(zhuǎn)換序列或集合

在c#或vb中我們不能實(shí)現(xiàn)把序列從t類型轉(zhuǎn)換為u類型,即使t從u類繼承。因此,即使把list轉(zhuǎn)換為list,如果我們需要轉(zhuǎn)換list為list,linq組合查詢也提供了解決方案,但是它會進(jìn)行列表的復(fù)制:

  1. list strlist = …;  
  2.  
  3. listobjlist = new list(strlist.cast()); 

chris cavanagh建議另外一種解決方式:

  1. var objlist = strlist.cast().tolist();  

6. 把值轉(zhuǎn)換為長度為1的序列

當(dāng)我們需要把單個(gè)值轉(zhuǎn)化為一個(gè)長度為1的序列時(shí),會怎么做?我們可以創(chuàng)建一個(gè)長度為1的數(shù)組,但是我還是喜歡linq組合查詢的repeat操作:

  1. ienumerable seq = enumerable.repeat(myvalue, 1); 

7. 遍歷序列的所有子集

有的時(shí)候,遍歷數(shù)組的所有子集很有用。子集和問題、布爾可滿足性問題以及背包問題都可以通過遍歷某個(gè)序列的所有子集來簡單解決。

有了linq組合查詢,我們可以如下聲場所有arr數(shù)組的子集:

  1. t[] arr = ...;  
  2.  
  3. var subsets = from m in enumerable.range(0, 1 << arr.length)  
  4.  
  5.               select  
  6.  
  7.                   from i in enumerable.range(0, arr.length)  
  8.  
  9.                   where (m & (1 << i)) != 0  
  10.  
  11.                   select arr[i]; 

注意,如果子集的個(gè)數(shù)超過了int,上面的代碼就不能工作。因此,僅當(dāng)你知道arr的長度不超過30的時(shí)候才去使用這個(gè)方式。如果arr長度超過30,你應(yīng)該不會是想去遍歷所有的子集,因?yàn)榭赡苓@會耗費(fèi)幾分鐘或更長的時(shí)間。

評論和總結(jié)

希望這些技巧對你有用,這些示例代碼都使用c#實(shí)現(xiàn),但是你可以很容易得改變?yōu)槠渌?net語言。然而,linq組合查詢對于支持?jǐn)U展方法、lambda表達(dá)式和類型推斷的語言更方便,比如c#和vb。這里的每一段代碼都可行,但是我不能保證什么,請?jiān)谑褂们白屑?xì)檢查。

【編輯推薦】

  1. LINQ查詢的目的與實(shí)現(xiàn)手段
  2. LINQ查詢表達(dá)式深入剖析
  3. 實(shí)例二:綁定到LINQ查詢的結(jié)果
  4. LINQ——語言級集成查詢?nèi)腴T指南
  5. LINQ的演變及其對C#設(shè)計(jì)的影響
責(zé)任編輯:林琳 來源: gzu521.com
相關(guān)推薦

2009-09-07 21:25:59

Linq自定義

2009-09-07 22:54:03

Linq組合查詢

2009-09-07 20:40:48

LINQ子查詢

2009-09-17 09:45:36

LINQ查詢語句

2010-05-17 09:34:46

LINQAjax

2012-04-13 10:00:04

LINQ

2009-09-15 17:45:34

Linq多條件

2009-09-15 10:46:04

LINQ to SQL

2009-09-16 10:38:43

LINQ查詢

2009-09-17 13:15:20

LINQ查詢

2009-09-16 10:08:06

LINQ查詢

2009-09-09 16:53:53

LINQ查詢語法

2009-09-10 16:28:17

LINQ查詢

2009-09-14 10:09:26

LINQ查詢結(jié)果

2009-09-14 10:13:02

LINQ查詢操作

2009-09-08 17:27:18

LINQ to Dat

2013-12-10 09:13:19

FreneticPyreticOpenFlow

2021-12-07 11:31:47

Python代碼if…elif…els

2009-09-07 17:05:10

LINQ進(jìn)行查詢

2009-09-08 09:24:50

LINQ查詢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號