LINQ中的Func委托

一个使用了Func委托的小例子

//创建一个整型数组
int[] intArray = new int[] { 0, 1, 2, 3 };
//声明Func委托, 判断是否是奇数
Func<int, bool> IsOdd = i => ((i & 1) == 1);
//执行查询操作, 别忘了具有"延迟特性"
IEnumerable<int> items = intArray.Where(IsOdd);
//显示结果
foreach (int item in items)
    Console.WriteLine(item);

        程序如我所愿的找出了intArray中的奇数有哪些. 但背后Func委托实质上为我们省去了哪些步骤呢? 我首先研究了LINQ查询中的委托.

LINQ中where查询的原型

        在我的一篇介绍lambda表达式的博客中有一个例子. 例子描述了这样一种情况: 有一个int型数组, 需要找出其中的奇数, 偶数等等等. 下面再贴出这个例子有用部分的完整代码:

using System;
using System.Collections;

namespace LinqTest
{
    class Program
    {
        public class Commom
        {
            //命名一个委托方法
            public delegate bool IntFilter(int i);
            //筛选出符合委托方法所要求的int, 返回一个int[]
            public static int[] FilterArrayOfInts(int[] ints, IntFilter filter)
            {
                ArrayList aList = new ArrayList();
                foreach (int i in ints)
                    if (filter(i))
                        aList.Add(i);
                return (int[])aList.ToArray(typeof(int));
            }
        }

        //根据需要, 自己定义筛选方法
        public class MyIntFilter
        {
            //自己定义的筛选方法1: 检测是否是奇数
            public static bool IsOdd(int i)
            {
                return ((i & 1) == 1);
            }
            //自己定义的筛选方法2: 检测是否是偶数
            public static bool IsEven(int i)
            {
                return ((i & 1) != 1);
            }
            //...根据需要还可以定义其它筛选方法
        }
        static void Main(string[] args)
        {
            int[] nums = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
            //筛选出奇数
            int[] oddNums = Commom.FilterArrayOfInts(nums, i => ((i & 1) == 1));
            foreach (int i in oddNums)
                Console.Write(i + " ");
        }
    }
}

        这个例子自己定义的一个Commom类, 并有一个筛选出一定要求的方法FilterArrayOfInts, 如果我们使用扩展方法将FilterArrayOfInts扩展到int[]类型, 将FilterArrayOfInts方法名改成where, 那就很有趣了, 那么最后筛选出奇数的代码就是这个样子的:

int[] nums = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
//筛选出奇数
int[] oddNums = nums.where(i => ((i & 1) == 1));

        是不是非常像LINQ中的where? 其实就是这么个道理.

Func委托的作用

        <LINQ技术详解>里面是这么说的: 可以防止开发者显式声明委托类型.

        什么意思呢? 上面的代码还是有用的, 可以这样理解, 上面代码中MyIntFilter类中定义了很多筛选一定条件整数的方法, 有方法就会有方法返回类型, 方法如果有参数就会还有参数类型. 如下:

//自己定义的筛选方法1: 检测是否是奇数
public static bool IsOdd(int i)
{
    return ((i & 1) == 1);
}
//自己定义的筛选方法2: 检测是否是偶数
public static bool IsEven(int i)
{
    return ((i & 1) != 1);
}

        Func委托将定义这些方法的代码变得简单, 如果是上面的这两个方法, 利用Func委托只需要这样写:

Func<int, bool> IsOdd = i => ((i & 1) == 1);
Func<int, bool> IsEven = i => ((i & 1) != 1);

        这样子在写法上就比较简单, 并且一看就明了代码是什么意思.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
表达式目录树是一个强大的功能,可以将代码表示为树形结构,以便在运行时进行解析。使用表达式目录树可以编写更灵活,可扩展和类型安全的代码。在 .NET ,可以使用表达式目录树委托来创建表达式目录树。下面是一个完整的示例,演示如何使用表达式目录树委托: ```csharp using System; using System.Linq.Expressions; class Program { static void Main() { // 定义参数 ParameterExpression x = Expression.Parameter(typeof(int), "x"); ParameterExpression y = Expression.Parameter(typeof(int), "y"); // 创建表达式目录树 BinaryExpression sum = Expression.Add(x, y); // 创建委托 Func<int, int, int> sumFunc = Expression.Lambda<Func<int, int, int>>(sum, x, y).Compile(); // 使用委托计算结果 int result = sumFunc(1, 2); Console.WriteLine(result); } } ``` 在这个例子,我们首先定义了两个参数 `x` 和 `y`,它们分别表示要相加的两个整数。然后,我们创建了一个 `BinaryExpression` 对象,它表示将 `x` 和 `y` 相加的操作。接着,我们使用 `Expression.Lambda` 方法将表达式目录树转换为一个委托,并编译它以生成可执行代码。最后,我们使用生成的委托计算 `1 + 2` 的结果并输出它。 请注意,表达式目录树的主要优点之一是它们是类型安全的。在上面的示例,我们明确指定了参数和返回值的类型,因此编译器可以在编译时执行类型检查,从而避免在运行时出现类型错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值