今天给大家整理一下C#中lambda表达式的一些常用技巧

"Lambda表达式"属于一个匿名函数,是一种针对C#编程语言高效的类似于函数式编程的表达式。采用Lambda简化了匿名委托的使用,可以大大减少开发中需要编写的代码量。比如针对一些求和、去重、排序等等可以省去了循环遍历的写法,使得代码变得更加简洁。
访问修饰符 修饰符 返回值类型 方法名(参数列表) => 表达式;
public static int Add(int a, int b) => a + b;
Lambda的本质就是方法匿名方法。
通过lambda表达式可以访问lambda表达式块外的变量,这称为闭包。
int lamValue = 10;
Func sum = x => x+lamValue;
当外部变量的值变动时,也会影响sum的结果,不建议这样写。
编译器会创建一个匿名类,它有一个构造函数来传递外部变量。
public class AnonymousClass{public int lamValue;public AnonymousClass(int lamValue){this.lamValue = lamValue;}public int AnonymousMethod(int x) => x+lamValue;
}
using System;namespace Study
{[Serializable]public class Goods{/// /// 商品名称/// public string Name { get; set; }/// /// 商品分类名称/// public string CategoryName { get; set; }/// /// 商品编码/// public string Code { get; set; }/// /// 商品单价/// public double Price { get; set; }/// /// 商品数量/// public int Count { get; set; }}
} using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;namespace Study
{class Program{static void Main(string[] args){var list = new List();
list.Add(new Goods{
Name = "小米12",
CategoryName = "手机",
Price = 3500.00,
Code = "001",
Count = 10});
list.Add(new Goods{
Name = "联想T50",
CategoryName = "笔记本",
Price = 8800.00,
Code = "002",
Count = 25});
list.Add(new Goods{
Name = "雷柏键鼠套装",
CategoryName = "数码",
Price = 688.00,
Code = "003",
Count = 60});
list.Add(new Goods{
Name = "华为蓝牙耳机",
CategoryName = "数码",
Price = 998.00,
Code = "004",
Count =7});// 筛选分类是数码的数据var list1 = list.Where(m => m.CategoryName == "数码").ToList();// 筛选分类是数码或者手机的记录var list2 = list.Where(m => m.CategoryName == "数码" || m.CategoryName=="手机").ToList();// 按照价格升序排序var list3 = list.OrderBy(m => m.Price).ToList();// 按照价格降序var list4 = list.OrderByDescending(m => m.Price).ToList();// 按照分类进行分组只展示分类名称var list5 = list.GroupBy(m => m.CategoryName).ToList();// 查询分类是数码的商品的总数量var list6 = list.Where(m=>m.CategoryName=="数码").Sum(m => m.Count);// 查询商品名称包含机这个关键字的平均价格var list7 = list.Where(m => m.Name.Contains("机")).Average(m => m.Price);// 根据分类进行分组 获取分类名、总数量、平均单价var list8 = list.GroupBy(m => m.CategoryName).Select(n => new Goods{
CategoryName=n.FirstOrDefault().CategoryName,
Price=n.Average(s=>s.Price),
Count = n.Sum(s => s.Count)});// 获取当前列表的前两行记录var list9 = list.Take(2).ToList();// 获取后两行数据var list10 = list.TakeLast(2).ToList();// 针对列表内存形式的分页 跳过第一条记录,往后查询两条var list11 = list.Skip(1).Take(2).ToList();// 针对整个列表所有属性比对去重var list12 = list.Distinct().ToList();// 根据分类名称去重var list13 = list.Select(m => m.CategoryName).Distinct().ToList();// 逗号拼接字符串 针对数值类型字段的拼接 获取前端字符串展示var json1 = string.Join(',', list.Select(m => m.Code));// 逗号加'' 单引号拼接字符串主要是用来数据库字段不为数值类型的 in 查询sql拼接var json2 = string.Join("','", list.Select(m => m.Name));
Console.WriteLine(json1);
Console.WriteLine("逆序之前");foreach (var item in list){
Console.WriteLine(JsonConvert.SerializeObject(item));}// list 逆序操作
list.Reverse();
Console.WriteLine("逆序之后");foreach (var item in list){ Console.WriteLine(JsonConvert.SerializeObject(item));} Console.WriteLine("Hello World!");}}
}