最近做一个实习工作,上头交代我写系统日志的操作,当时上头说用ado.net的Ef(基于数据库的实体模型)开发。 主要一个函数 :
public List SelectBy(Expression> wherelamdba)
{ using (LogEntities lg = new LogEntities())
{ return lg.vUserLogs.Where(wherelamdba).ToList(); }}
但是上头看了一下我写的代码,说我用lamdba表示作为参数,执行效率低!复杂!!主要:
(1)(LogEntities是实体模型的上下文的类,有两个dbset表),在使用中(l= lg.vUserLogs.Where(wherelamdba).ToList();)l和lg(也就是dbset)不释放;
(2)委托是反射吗?当时我就说lamdba不是委托吗?他说委托本质是反射;
我现在还是刚学c#没多久,帮忙解惑一下。谢谢!

asp.net关于用Lambda表达式做函数参数效率问题
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- q107770540 2014-11-22 14:48关注
效率低不低 要拿出数据来说明的
lmada表达式的效率比反射高出几个数量级
相信看过老赵的文章的 都会明白的
第1个问题,竟然会说出这样的疑问,你的所谓“上头”根本就是在不懂装懂,问题就曝露了他的无知
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报