Kal*_*exx 3 .net yield-return c#-3.0
在我的MVC应用程序的服务层中,我试图将linq转换为sql实体结果到我的业务模型实体中.我目前正在尝试以下代码:
public IList<Project> GetAllProjects()
{
var results = from p in _context.Repository<DBMappings.project>()
select p;
foreach (DBMappings.project prj in results.ToList<DBMappings.project>())
yield return CreateProjectEntityFromDBProject(prj);
}
Run Code Online (Sandbox Code Playgroud)
不幸的是,这似乎不起作用,我唯一可以猜到的是,yield只适用于IEnumerable.除了创建新列表,在foreach循环中添加项目并返回列表之外,还有其他解决方案吗?我需要使用IList,因为使用返回列表的方法需要能够执行列表方法,如.Sort().
如果你愿意,.Sort()
你一定要在你的方法中创建一个列表.使用yield可以节省一些内存 - 因为结果不会存储为单个对象.当您只想查看结果时,这非常有用.但是如果你想对内存中的东西进行排序,你需要将它作为一个单独的内存.
归档时间: |
|
查看次数: |
1143 次 |
最近记录: |