u010992424
u010992424
采纳率100%
2014-11-22 13:49 浏览 2.4k

asp.net关于用Lambda表达式做函数参数效率问题

最近做一个实习工作,上头交代我写系统日志的操作,当时上头说用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#没多久,帮忙解惑一下。谢谢!

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答 默认 最新

  • 已采纳
    q107770540 兔子党-督察 2014-11-22 14:48

    效率低不低 要拿出数据来说明的

    lmada表达式的效率比反射高出几个数量级

    相信看过老赵的文章的 都会明白的

    第1个问题,竟然会说出这样的疑问,你的所谓“上头”根本就是在不懂装懂,问题就曝露了他的无知

    点赞 3 评论 复制链接分享
  • microtry 缪军 2014-11-23 02:08

    我关心的是开发效率,测试接口没有说明的我不考虑;

    如果不能尽快通过测试,就算你把C#所有最时髦的语法用上,也毫无意义,
    而历史的经验告诉我们:越是简单的越具有重用价值;

    lamdba也好,LinQ也好,我很少用到,这些技术对于提高产能没有明显的帮助,
    在这些技术没有的时候,开发者早就用各自的技术手段实现了类似的效果,
    当然,我并不反对同事使用这些技术,
    原因是:对于工单,程序员会拿出自己最熟练的本事,以最快的速度通过测试

    点赞 1 评论 复制链接分享

相关推荐