在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
对象初始化器:实例化一个对象的时候给其属性赋值 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都直接省略了 |
请发表评论