C#中yield return用法分析
本文實例講述了C#中yield return用法,并且對比了使用yield return與不使用yield return的情況,以便讀者更好的進(jìn)行理解。具體如下:
yield關(guān)鍵字用于遍歷循環(huán)中,yield return用于返回IEnumerable<T>,yield break用于終止循環(huán)遍歷。
有這樣的一個int類型的集合:
static List<int> GetInitialData()
{
return new List<int>(){1,2,3,4};
}
需要打印出所有值大于2的元素。
不使用yield return的實現(xiàn)
static IEnumerable<int> FilterWithoutYield()
{
List<int> result = new List<int>();
foreach (int i in GetInitialData())
{
if (i > 2)
{
result.Add(i);
}
}
return result;
}
客戶端調(diào)用:
static void Main(string[] args)
{
foreach (var item in FilterWithoutYield())
{
Console.WriteLine(item);
}
Console.ReadKey();
}
輸出結(jié)果:3,4
使用yeild return實現(xiàn)
static IEnumerable<int> FilterWithYield()
{
foreach (int i in GetInitialData())
{
if (i > 2)
{
yield return i;
}
}
yield break;
Console.WriteLine("這里的代碼不執(zhí)行");
}
客戶端調(diào)用:
static void Main(string[] args)
{
foreach (var item in FilterWithYield())
{
Console.WriteLine(item);
}
Console.ReadKey();
}
輸出結(jié)果:3,4
總結(jié):
通過單步調(diào)試發(fā)現(xiàn):
雖然2種方法的輸出結(jié)果是一樣的,但運(yùn)作過程迥然不同。第一種方法,是把結(jié)果集全部加載到內(nèi)存中再遍歷;第二種方法,客戶端每調(diào)用一次,yield return就返回一個值給客戶端,是"按需供給"。
第一種方法,客戶端調(diào)用過程大致為:

使用yield return,客戶端調(diào)用過程大致為:

使用yield return為什么能保證每次循環(huán)遍歷的時候從前一次停止的地方開始執(zhí)行呢?
--因為,編譯器會生成一個狀態(tài)機(jī)來維護(hù)迭代器的狀態(tài)。
簡單地說,當(dāng)希望獲取一個IEnumerable<T>類型的集合,而不想把數(shù)據(jù)一次性加載到內(nèi)存,就可以考慮使用yield return實現(xiàn)"按需供給"。
希望本文所述對大家的C#程序設(shè)計有所幫助。
相關(guān)文章
C# .net core HttpClientFactory用法及說明
這篇文章主要介紹了C# .net core HttpClientFactory用法及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
C#多線程學(xué)習(xí)之(五)使用定時器進(jìn)行多線程的自動管理
這篇文章主要介紹了C#多線程學(xué)習(xí)之使用定時器進(jìn)行多線程的自動管理,實例分析了C#使用timer定時器類實現(xiàn)針對多線程的自動管理功能,非常具有實用價值,需要的朋友可以參考下2015-04-04
Win10下C# DateTime出現(xiàn)星期幾問題的解決方法
這篇文章主要介紹了Win10下C# DateTime出現(xiàn)星期幾問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10

