119

我有一个我希望能够传递和重用的 lambda 表达式。这是代码:

public List<IJob> getJobs(/* i want to pass the lambda expr in here */) {
  using (SqlConnection connection = new SqlConnection(getConnectionString())) {
    connection.Open();
    return connection.Query<FullTimeJob, Student, FullTimeJob>(sql, 
      (job, student) => {         
        job.Student = student;
        job.StudentId = student.Id;
        return job;
        },
        splitOn: "user_id",
        param: parameters).ToList<IJob>();   
  }   

这里的关键是我希望能够将我在这里使用的 lambda 表达式传递给调用此代码的方法,以便我可以重用它。lambda 表达式是我的 .Query 方法中的第二个参数。我假设我想使用 Action 或 Func,但我不太确定它的语法是什么或它是如何工作的。有人可以给我一个例子吗?

4

4 回答 4

136

使用Func<T1, T2, TResult>委托作为参数类型并将其传递给您的Query

public List<IJob> getJobs(Func<FullTimeJob, Student, FullTimeJob> lambda)
{
  using (SqlConnection connection = new SqlConnection(getConnectionString())) {
    connection.Open();
    return connection.Query<FullTimeJob, Student, FullTimeJob>(sql, 
        lambda,
        splitOn: "user_id",
        param: parameters).ToList<IJob>();   
  }  
}

你会这样称呼它:

getJobs((job, student) => {         
        job.Student = student;
        job.StudentId = student.Id;
        return job;
        });

或者将 lambda 分配给一个变量并将传入。

于 2013-01-12T20:28:51.443 回答
30

如果我了解您需要以下代码。(通过参数传递表达式 lambda)方法

public static void Method(Expression<Func<int, bool>> predicate) { 
    int[] number={1,2,3,4,5,6,7,8,9,10};
    var newList = from x in number
                  .Where(predicate.Compile()) //here compile your clausuly
                  select x;
                newList.ToList();//return a new list
    }

调用方法

Method(v => v.Equals(1));

你可以在他们的课堂上做同样的事情,看这个例子。

public string Name {get;set;}

public static List<Class> GetList(Expression<Func<Class, bool>> predicate)
    {
        List<Class> c = new List<Class>();
        c.Add(new Class("name1"));
        c.Add(new Class("name2"));

        var f = from g in c.
                Where (predicate.Compile())
                select g;
        f.ToList();

       return f;
    }

调用方法

Class.GetList(c=>c.Name=="yourname");

我希望这是有用的

于 2015-04-24T02:34:35.253 回答
10

Lambda 表达式的类型为Action<parameters>(如果它们不返回值)或Func<parameters,return>(如果它们有返回值)。在您的情况下,您有两个输入参数,并且需要返回一个值,因此您应该使用:

Func<FullTimeJob, Student, FullTimeJob>
于 2013-01-12T20:29:07.960 回答
5

您应该使用委托类型并将其指定为您的命令参数。您可以使用其中一种内置委托类型 -ActionFunc.

在您的情况下,您的委托看起来像接受两个参数,并返回一个结果,因此您可以使用Func

List<IJob> GetJobs(Func<FullTimeJob, Student, FullTimeJob> projection)

然后,您可以调用GetJobs传递委托实例的方法。这可以是与该签名匹配的方法、匿名委托或 lambda 表达式。

PS您应该使用 PascalCase 作为方法名称 - GetJobs,而不是getJobs

于 2013-01-12T20:30:45.630 回答