有时候,我们需要封装一组数据,只有数据,没有方法,并且只用于当前程序,不需要在项目间重用,这时候,如果是传统的使用类来封装的话,大概会是下面这种样子:
internal class SomeData
{
//定义一系列私有成员变量
//创建属性来封装每一个数据成员
//重写方法的ToString()来输出每一个数据成员
//重写GetHashCode() 及Equals()来实现基于值的相等性
}
这个虽然不难,但如果数据量比较多,显然写起来就比较麻烦了。因此,C#3.0以后提供了一个叫匿名类型的机制,来简化这一任务。如下:
var myCar = {Color="Black",Make="China",Name="Puma",Price=5000000);
这就是一个匿名类型的对象!因为这个类并没有具体的类型名可用,因此,这时是var派用场的好时候。C#编译器在编译时会自动生成名称唯一的一个类,并且所有的成员变量都自动在后台被封装为属性。所有的匿名类型都直接继承自System.Object,并且重写了方法Equals(),GetHashCode(),ToString()等方法。其中,ToString()是根据每一个成员变量的名称、值对,生成一个拼接字符串。
当定义了两个相同的字段、值对的匿名对象时,用Equals()比较,就会发现它们是相等的。但是,这时的 == , != 运算符是不能用的,因为编译器并没有自动重载这些。
当一个新的匿名对象定义与前面已经存在的类型定义的内部变量类型相同时,编译器就会只生成一个类定义,而不是各一个。
匿名类型对象中仍然可以再包含匿名对象。
在LINQ中,匿名类型又会派上大用场!!!
总结:匿名方法本质上是一传递给委托的代码块,是使用委托的另一种方法。
规则:
1、匿名方法中不能使用跳转语句跳至次匿名方法的外部,反之亦然;匿名方法外部的跳转语句也不能跳转到匿名方法的内部;
2、在匿名方法的内部不能访问不安全的代码。另外,也不能访问在匿名方法外部定义的ref和out参数。
3、可以使用在匿名方法外部定义的其他变量。
拉姆达表达式:就是匿名方法,只是语法不同。
(param)=>expr
param是输入参数列表,expr是一个表达式或者一系列语句。
规则:
1、在一个具有唯一的显示类型参数的Lambda表达式中,圆括号可以从参数列表中删除。
2、当输入参数不唯一时,括号不能省略。
3、输入参数列表中的各参数可以显式指定类型,也可以省略参数类型,具体类型通过类型判断机制判断。
4、expr可以只包含一个计算表达式,也可以包含一系列语句,只是语句需要包含在大括号中。
expr 为语句的时候:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace DelegateSample
{
public delegate void PrintDelegate(string content);
class Program
{
static void Main(string[] args)
{
PrintDelegate pd = (string str) =>
{
System.Console.WriteLine("Printing...");
System.Console.WriteLine("Content:{0}", str);
};
pd("The quick brown fox jumps oyer a lazy dog.");
}
}
}