例子:在不使用yieId时,通常我们都会采取先遍历再把元素加到新的List中
using (var reader = SqlHelper.ExecuteReader("")) { if (reader.HasRows) { IList<Captcha> list = new List<Captcha>(); while (reader.Read()) { list.Add(SqlHelper.MapEntity<Captcha>(reader)); } return list; } } return null;
接下来我们用它(yieId)来改善以上代码:
using (var reader = SqlHelper.ExecuteReader("")) { if (reader.HasRows) { while (reader.Read()) { yield return SqlHelper.MapEntity<Captcha>(reader); } } }
这里需要注意的是在使用yieId时,返回值类型必须为IEnumerable
现在我们简单介绍下yieId,先分享一个错误的理解,注意 是错误的理解
时间: 2024-12-12 12:14:42