C#之初始化器和匿名类

对象初始化器:实例化一个对象的时候给其属性赋值

People p=new People{Id=1,Name=”test”,Age=12};

当然对象初始化器可以给部分属相赋值

集合初始化器的例子

List<Peolpe> p =new List<People>{new People{Id=1,Name=”test”,Age=12},

new People{Id=1,Name=”test”,Age=12},

new People{Id=1,Name=”test”,Age=12}};

其他类型的初始器

数组使用初始化器:

string [] test={“a”,”b”,”c”};

匿名类型使用初始化器:

var test=new {Title=“a”,author=”b”};

字典使用初始化器:

Dictionary<string,int> test=new Dictionary<string,int>(){{“A”,”1”},{“b”,12}}

匿名类

在匿名类中利用var推断类型构造了一个匿名类

var annoyCla1 = new
    {
        ID = 1,
        Name = "test",
        Age = 12
    };

利用Refecltor可以看到,实际编译器帮我们内部生成了一个

如果给匿名类型对象的属性赋值则会报错,因为其匿名类型的属性是只读的,并且其重写类三个基类的方法

匿名函数的共享

如果其定义了多个匿名类其规则相同,则这个多个匿名类则会共享一个泛型类

(1)如果定义的匿名类与之前定义过的一模一样:属性类型和顺序都一致,那么默认共享前一个泛型类

(2)如果属性名称和顺序一致,但属性类型不同,那么还是共同使用一个泛型类,只是泛型参数改变了而已,所以在运行时会生成不同的类:

(3)如果数据型名称和类型相同,但顺序不同,那么编译器会重新创建一个匿名类

匿名方法

介绍匿名方法就必须先看看一个简单委托的定义

public delegate void DelegeteTest(string test);

我们定义了一个委托但是这个委托是输入参数为string字符串,返回为空的一个委托

接着我们定义一个满足这些规则的方法来实现这个委托

public void Test(string name)
        {
            Console.WriteLine("Hello,{0}", name);
        }

接着我们给这个委托添加这个方法

DelegateTest dgTest = new DelegateTest(TestFunc);
   dgTest("test");

定义一个委托实现方法输出test

如果再这个程序中,这个Test方法只是被这个匿名方法,这样的实现构造就会有些麻烦,所以微软就给我们推出了匿名方法

上面给委托注册方法的实现我们现在就用匿名函数的来实现

DelegateTest dgTest2 = new DelegateTest(delegate(string name)
{
      Console.WriteLine("Good,{0}", name);
});

可以看出匿名函数的实现结构方式

原本需要传递方法名的地方我们直接传递了一个方法,这个方法以delegate(参数){方法体}的格式编写,在{}里边直接写了方法体内容

经过反编译查看这种实现方式其实也,匿名函数也是给我们给我定义了一个私有字段的委托delegate,并且帮我们生成一个方法

匿名函数的语法糖扩展

DelegateTest dgTest3 = delegate(string name)
        {
           Console.WriteLine("Good,{0}", name);
        };

通过这种实现可以看出连new DelegateTest都直接省略了

原文地址:https://www.cnblogs.com/ilooking/p/4137433.html