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

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条回答 默认 最新

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

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

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

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

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

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • 缪军 2014-11-23 02:08

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

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

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

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题