介绍:
“Lambda表达式”(lambda expression)是一个匿名函数,在C#3.0中引入了lambda表达式,它是对匿名函数的一种简化,可以包含表达式和语句,并且可用于创建委托或表达式目录树类型。
如何创建
格式:( 形参列表 ) => { 函数体 }
若要创建 Lambda表达式,需要在 Lambda运算符=>左侧指定输入参数(如果有),然后在另一侧输入表达式或语句块。例如,lambda表达式 x => x * x指定名为 x的参数并返回 x的平方值。如下面的示例所示,你可以将此表达式分配给委托类型:
delegate int del(int i);
static void Main(string[] args)
{
del myDelegate = x => x *x;
int j = myDelegate(5); //j = 25
}
注意:函数体多于一条语句的可用大括号括起。
以上函数体也可以写成
del myDelegate = x => { return x * x;};
使用 Lambda表达式
=> 运算符具有与赋值运算符 (=) 相同的优先级并且是右结合运算
仅当 lambda 只有一个输入参数时,括号才是可选的;否则括号是必需的。括号内的两个或更多输入参数使用逗号加以分隔:
(x,y) => x == y
使用Lamdba语句
语句 lambda 与表达式 lambda 表达式类似,只是语句括在大括号中:
delegatevoid TestDelegate(string s);
…
TestDelegatemyDel = n => { string s = n + " " + "World";Console.WriteLine(s); };
myDel("Hello");
代码中如何利用Lamdba
Lambda 在基于方法的 LINQ 查询中用作标准查询运算符方法(如Where)的参数。参数是委托类型System.Func<T, TResult>。 使用 Lambda 表达式创建该委托最为方便。
看实例
public delegate TResult Func<TArg0, TResult>(TArg0 arg0)
可以将委托实例化为 Func<int,bool> myFunc,其中 int是输入参数,bool 是返回值。 返回值始终在最后一个类型参数中指定。 Func<int, string, bool>定义包含两个输入参数(int 和 string)且返回类型为 bool 的委托。 当调用下面的 Func 委托时,该委托将返回 true 或 false以指示输入参数是否等于 5:
Func<int,bool> myFunc = x => x == 5;
boolresult = myFunc(4); // returns false of course
//项目中用到的一个小例子
public CommodityCollection Load(string type)
{
return this.Load(p =>
{
p.AppendItem("Code",type);
});
}
return中的load方法实际上是一个具有泛型的委托,p为继承实现了SqlClauseBuilderUW的方法
[Serializable]
public abstract class SqlClauseBuilderUW : SqlClauseBuilderIUW
{
protected SqlClauseBuilderUW();
public SqlClauseBuilderUW AppendItem<T>(string dataField, T data, string op, string template);
public SqlClauseBuilderUW AppendItem<T>(string dataField, T data, string op, string template, bool isExpression);
protected override SqlClauseBuilderItemBase CreateBuilderItem();
}
public TCollection Load(Action<WhereSqlClauseBuilder> whereAction);
namespaceSystem
{
// 摘要:
// 封装一个方法,该方法只有一个参数并且不返回值。
//
// 参数:
// obj:
// 此委托封装的方法的参数。
//
// 类型参数:
// T:
// 此委托封装的方法的参数类型。
public delegate void Action<in T>(T obj);
}
小结:
综合应用可以看出Lamdba可以简化查询的方法,并且在Linq的使用中多与泛型委托,枚举的where方法结合使用。是查询方式简化了很多,但是内部构造却与匿名函数相同的.也是刚刚接触了解,不足之处还请谅解。