對於」yield」這個關鍵字我已經見過n次了,直到最近我才知道這個關鍵字所蘊含的力量。我將在下面展示出一些使用」yield」讓你的**有更高可讀性和更好效能的例子.
為了讓你對yield有一些快速概覽,我首先要展示乙個沒有使用這個關鍵字的例子,下面的**很簡單,但在我最近的專案中卻很常見
ilistfindbobs(ienumerablenames)return bobs;
}
注意在這裡我使用ienumerable作為引數型別並以ilist作為返回型別,通常來說,我更傾向於在引數輸入的型別方面的範圍越寬越好,但在返回型別上面更加嚴格(譯者按:即輸入時多用基類或介面,返回時用子類或實現類),對於輸入來說,如果你需要用foreach來對其進行迴圈的話,使用ienumerable會更有意義。而對於輸出(譯者按:也就是返回),我使用介面來讓實現部分可以改變。在這裡我想讓呼叫者省去生成列表的麻煩,所以我選擇list作為返回型別.
而問題在於,我的設計並不具有可鏈結性,這樣的設計需要產生列表作為返回值,實現上,這個列表或許不會很大,但這並不必要
現在,讓我們來看看以「yield」的方式來做這些,而後我會解釋如何使用它,以及它工作的原理。
ienumerablefindbobs(ienumerablenames)}
在這個版本中,我們將返回型別改為ienumerable,並且我們使用」yield return」.注意我再也不需要建立乙個列表,現在是不是有些迷惑的?別著急,在理解它的工作方式的情況它會變的越來越簡單.
傳統的執行方法
呼叫函式
函式執行並返回list
呼叫部分使用返回的list
yield的執行方法
呼叫函式
呼叫者請求item
下乙個item返回
回到步驟2
雖然yield執行的實現貌似有些複雜,但我們最終只需要一次「彈出」乙個item,而不是建立整個list並返回.
對於句法說,我個人認為yield更加簡潔,並且對於傳遞函式的用途表現的更好(譯者按:也就是**可讀性),我使用ienumerable作為返回型別來通知呼叫者它可以被foreach迴圈並且返回資料,而呼叫者現在可以自己決定它是否願意將返回值存放到列表中,即使這會以效能作為代價。
在我提供的這個簡單例子中,也許你並不能發現很多使用yield的好處,然而,你可以在呼叫者需要取消遍歷所有的函式提供的內容時節省很多不必要的工作,當你在方法鏈結時使用yield,你可以省下的工作(時間)或許會成倍疊加。
最開始我對yield的保留意見是使用這個關鍵字或許會導致潛在的效能問題,但實際上,至今為止我還未能發現任何資訊來說明關於yield對效能的影響,而我在上面提到提高效能的地方遠遠大於編譯器overhead那部分。
yield可以讓你的**更加高效並擁有更高的可讀性,已經是.net 2.0時代了,我想已經沒有什麼藉口可以阻止我們學習和使用yield.
使用C yield關鍵字來提高效能和可讀性
譯 使用c yield關鍵字來提高效能和可讀性 c 2.0 中yield我一直以來都沒怎麼好好理解過。直到今天偶然乙個機會我在研究一段 時又再次遇到了它,然後我在網上查了下,發現下面的這篇文章介紹的最為通俗易懂,所以我轉了過來,原文如下 對於 yield 這個關鍵字我已經見過n次了,直到最近我才知道...
C yield 關鍵字 使用
在語句中使用 yield 關鍵字,則指示在的方案 運算子或 get 訪問器是迭代器。使用的迭代器對集合的自定義迭代。使用乙個 yield return 語句返回每個元素乙個節點。例子 public class powersof2 i public static system.collections....
C yield關鍵字的使用
yield c 參考 在迭代器 塊中用於向列舉數物件提供值或發出迭代結束訊號。它的形式為下列之一 複製 yield return yield break 備註 計算表示式並以列舉數物件值的形式返回 expression 必須可以隱式轉換為迭代器的 yield 型別。yield語句只能出現在itera...