집 >백엔드 개발 >C#.Net 튜토리얼 >C#의 익명 대리자 및 람다 표현식의 예에 대한 자세한 설명
1. C# 1.0부터 4.0까지, Linq와 제네릭의 지원으로 코드가 점점 더 단순해지고 우아해졌습니다
1 int[] nums = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 }; 2 IEnumerable<int> newNums = from n in nums where n > 0 select n; 3 newNums = newNums.Where(new Func<int,int, bool>(delegate(int i,int index) { return i < index; })); 4 newNums = newNums.Where(new Func<int, int, bool>((int i, int index)=> i < index)); 5 newNums = newNums.Where(delegate(int i, int index) { return i < index; }); 6 newNums = newNums.Where((i, index) => i < index); 7 foreach (var i in newNums) 8 { 9 Console.WriteLine(i);10 }
2. 컬렉션 작업도 EF 데이터베이스 작업에 적용할 수 있습니다
1. 엔터티 클래스
1 public class Store 2 { 3 public string Id; 4 public string Name; 5 } 6 public class Person 7 { 8 public string name { get; set; } 9 public int age { get; set; }10 public string StoreId { get; set; }11 }
2. 데이터 삽입
1 var Stores = new List<Store>() 2 { 3 new Store() { Id="1",Name="1班"}, 4 new Store() { Id="2",Name="2班"} 5 }; 6 7 var Persons = new List<Person>() 8 { 9 new Person() { name="p1",age=1, StoreId="1"},10 new Person() { name="p2",age=2, StoreId="1"},11 new Person() { name="p3",age=3, StoreId="1"},12 new Person() { name="p4",age=4, StoreId="2"},13 new Person() { name="p5",age=5, StoreId="1"},14 new Person() { name="p6",age=6, StoreId="2"},15 new Person() { name="p7",age=7, StoreId="1"},16 new Person() { name="p8",age=8, StoreId="1"}17 };
3. 1학년과 2학년의 3세 미만 인원이 몇 명인지 쿼리합니다
1 var plst = Persons.Where(o => o.age > 3).GroupBy(o => o.StoreId).Select(g => new { StoreId = g.Key, Count = g.Count() }).Join(Stores, s => s.StoreId, p => p.Id, (s, p) => new { s.StoreId, storeName = p.Name, s.Count });2 foreach (var p in plst)3 {4 Console.WriteLine(p.storeName + "有" + p.Count + "个人");5 }
4.
위 내용은 C#의 익명 대리자 및 람다 표현식의 예에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!