W języku C # możesz konstruować metody z typem zwracanym IEnumerable<T>i używać yield returnoraz yield breakkontrolować przepływ. Oto prosty przykład, który wykorzystuje obie kontrolki:
public IEnumerable<int> GetEvens(int start, int end) {
if(end < start)
yield break;
if(start & 2 != 0)
start++;
for(int i = start; i <= end; i+=2) {
yield return i;
}
}
Moje pytanie brzmi: dlaczego pierwotnie zostało zaprojektowane, aby używać dwóch słów kluczowych yieldi nie używać go w następujący sposób z pojedynczym yield„zwracaniem wartości zwracanej”:
public IEnumerable<int> GetEvens(int start, int end) {
if(end < start)
return; // stop completely and return nothing
if(start & 2 != 0)
start++;
for(int i = start; i <= end; i+=2) {
yield i; // yield the current value.
}
}
Dla mnie jest to łatwiejsze do odczytania i zrozumienia.
yield x;też nie byłby błąd składniowy?