首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么必须在作为普通的Delegate参数提供时转换lambda表达式

在 C++ 中,当我们需要将一个 lambda 表达式作为普通的 Delegate 参数提供时,我们需要将其转换为相应的委托类型。这是因为委托是一个特定的类型,而 lambda 表达式本身没有类型。

例如,假设我们有一个名为 MyFunction 的函数,它接受一个委托类型 MyDelegate 的参数。我们可以将一个 lambda 表达式转换为 MyDelegate 类型,并将其作为参数提供给 MyFunction

代码语言:csharp
复制
public delegate void MyDelegate(int x);

public static void MyFunction(MyDelegate d)
{
    d(42);
}

public static void Main()
{
    MyFunction((int x) => Console.WriteLine(x));
}

在这个例子中,我们定义了一个名为 MyDelegate 的委托类型,它接受一个整数参数并返回 void。我们还定义了一个名为 MyFunction 的函数,它接受一个 MyDelegate 类型的参数。在 Main 函数中,我们将一个 lambda 表达式转换为 MyDelegate 类型,并将其作为参数提供给 MyFunction

如果我们尝试将 lambda 表达式直接作为参数提供给 MyFunction,而不进行转换,我们将会得到一个编译错误,因为 lambda 表达式没有类型,而 MyFunction 需要一个 MyDelegate 类型的参数。

代码语言:csharp
复制
MyFunction((x) => Console.WriteLine(x)); // 编译错误

因此,当我们需要将 lambda 表达式作为普通的 Delegate 参数提供时,我们需要将其转换为相应的委托类型。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

编写高质量代码改善C#程序的157个建议[为泛型指定初始值、使用委托声明、使用Lambda替代方法和匿名方法]

泛型并不是C#语言一开始就带有的特性,而是在FCL2.0之后实现的新功能。基于泛型,我们得以将类型参数化,以便更大范围地进行代码复用。同时,它减少了泛型类及泛型方法中的转型,确保了类型安全。委托本身是一种引用类型,它保存的也是托管堆中对象的引用,只不过这个引用比较特殊,它是对方法的引用。事件本身也是委托,它是委托组,C#中提供了关键字event来对事件进行特别区分。一旦我们开始编写稍微复杂的C#代码,就肯定离不开泛型、委托和事件。本章将针对这三个方面进行说明。

05
领券