一个关于linq效率的小问题

cannel 2011-09-04 04:22:25
现在想获得一个list中符合某条件的一个元素,如果超过一个则返回默认的第一个,如果没有则返回null

现在实现方式有两种
一:
var result = from t in tProjectORGs where t.CLASSID == tProjectGeneral.ID select t;
if (result.Count() > 0)
{
return result.ToList()[0];
}
else
{
return null;
}

二:
IList<AGSDM_PROJECT> tProjectInORGs = tProjectORGs.Where(t => t.CLASSID == tProjectGeneral.ID).ToList();
if (tProjectInORGs.Count > 0)
{
return tProjectInORGs[0];
}
else
{
return null;
}

请问哪种效果更优??
...全文
105 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
cannel 2011-09-04
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 q107770540 的回复:]
引用 5 楼 cannel 的回复:

引用 1 楼 dongxinxi 的回复:
上面两种编译后基本没什么区别,要用也是优先选用三目判断
其实写成下面这样最简单
var result = tProjectORGs.FirstOrDefault(p => p.CLASSID == tProjectGeneral.ID);


FirstOrDefault行吗?以前用过First,如……
[/Quote]

那也是
q107770540 2011-09-04
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 cannel 的回复:]

引用 1 楼 dongxinxi 的回复:
上面两种编译后基本没什么区别,要用也是优先选用三目判断
其实写成下面这样最简单
var result = tProjectORGs.FirstOrDefault(p => p.CLASSID == tProjectGeneral.ID);


FirstOrDefault行吗?以前用过First,如果筛选后的count为0会抛出异常,所以以……
[/Quote]
如果是一样 为什么MS会提供两个同样的东西呢?
cannel 2011-09-04
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 dongxinxi 的回复:]
上面两种编译后基本没什么区别,要用也是优先选用三目判断
其实写成下面这样最简单
var result = tProjectORGs.FirstOrDefault(p => p.CLASSID == tProjectGeneral.ID);
[/Quote]

FirstOrDefault行吗?以前用过First,如果筛选后的count为0会抛出异常,所以以为FirstOrDefault也一样
hztltgg 2011-09-04
  • 打赏
  • 举报
回复
你是取单个,为什么要ToList转换,又[0]取?
而且你需求不是已经有.FirstOrDefault扩展方法了么
vrhero 2011-09-04
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 dongxinxi 的回复:]
上面两种编译后基本没什么区别,要用也是优先选用三目判断
其实写成下面这样最简单
var result = tProjectORGs.FirstOrDefault(p => p.CLASSID == tProjectGeneral.ID);
[/Quote]
一句的事儿...楼主想玩linq就多看文档别自己瞎想...
  • 打赏
  • 举报
回复
尽可能少的产生中间变量
  • 打赏
  • 举报
回复
上面两种编译后基本没什么区别,要用也是优先选用三目判断
其实写成下面这样最简单
var result = tProjectORGs.FirstOrDefault(p => p.CLASSID == tProjectGeneral.ID);

8,497

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 LINQ
社区管理员
  • LINQ
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧