C#内置委托

一、Func

Func是一个.Net内置的委托。

Func<Result>,Func<T1,Result>是一个.Net内置的泛型委托。

  • Func<TResult>
  • Func<T,TResult>
  • Func<T1,T2,TResult>
  • Func<T1,T2,T3,TResult>
  • Func<T1,T2,T3,T4,TResult>

它有5种形式,只是参数个数不同;第一个是无参数,但是有返回值;

下面是一个简单的普通委托来传方法的示例。


1

2

3

4

5

6

7

8

9

10

11

12

private delegate string Say();

public static string SayHello()

{

    return "Hello";

}

static void Main(string[] args)

{

    Say say = SayHello;

    Console.WriteLine(say());

    Console.ReadKey();

}

所以,在有时候,我们不知道一个接口同时要做什么操作的时候,我可以给它留一个委托。

为了更方便,.Net直接默认有了委托。我们再来试试.Net默认带的委托。


1

2

3

4

5

6

7

8

9

10

11

public static string SayHello()

{

    return "Hello";

}

static void Main(string[] args)

{

    Func<string> say = SayHello;

    Console.WriteLine(say());

    Console.ReadKey();

}

如果需要参数的,还可以这样传一份。


1

2

3

4

5

6

7

8

9

10

11

12

public static string SayHello(string str)

{

    return str + str;

}

static void Main(string[] args)

{

    Func<stringstring> say = SayHello;

    string str = say("abc");   

    Console.WriteLine(str);     //输出abcabc

    Console.ReadKey();

}

二、Action

Action<T>的用法与Func几乎一样,调用方法也类似。

  • Action
  • Action<T>
  • Action<T1,T2>
  • Action<T1,T2,T3>
  • Action<T1,T2,T3,T4>

1

2

3

4

5

6

7

8

9

10

11

12

private delegate string Say();

public static void SayHello(string str)

{

    Console.WriteLine(str);

}

static void Main(string[] args)

{

    Action<string> say = SayHello;

    say("abc");

    Console.ReadKey();

}

三、Func与Action的区别

Func与Action作用几乎一样。只是

  • Func<Result>有返回类型;
  • Action<T>只有参数类型,不能传返回类型。所以Action<T>的委托函数都是没有返回值的。

四、Func与Action都支持Lambda的形式调用

还是以一个输入后,返回重复一次的值作为示例。


1

2

Func<stringstring> say = m => m + m;

Console.WriteLine(say("abc"));    //输出abcabc

五、最常见到Func的地方

通常我们最常见到Func是在方法的参数里如下面这样:


1

string XXX(Func<stringstring>)

咱们来看看Linq里面的其中一个Sum:


1

public static int Sum<TSource>(this IEnumerable<TSource> source, Func<TSource, int> selector);

里面看到两点:
1、扩展方法,与这篇文章无关(扩展的是IEnumerable<TSource>,主要是为了能够实现IEnumerable<TSource>接口的集合.出函数)。
2、Func<TSource, int> selector这个参数。
尝试写一个Linq的First函数吧,命名为First2。Linq源代码里有很多异常情况处理,好多设计模式,可惜我不懂,只提取简单逻辑了。


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

namespace ConsoleApplication2

{

    static class Extend

    {

        public static TSource First2<TSource>(this IEnumerable<TSource> source, Func<TSource, bool> predicate)

        {

            //.Net本身的源代码好多异常情况处理,好多设计模式,我也不懂,只提取逻辑

            foreach (TSource item in source)

            {

                if (predicate(item))

                {

                    return (item);

                }

            }

            throw new Exception("不存在满足条件的第一个元素!");

        }

    }

    class Program

    {

        static void Main(string[] args)

        {

            List<int> ListInt = new List<int>(){ 1, 2, 3, 4, 5 };

            int k = ListInt.First2(m => m > 4);     //输出5

            Console.WriteLine(k);

            Console.ReadKey();

        }

    }

}

时间: 2024-10-05 06:05:27

C#内置委托的相关文章

委托+内置委托方法

委托概念:如果我们要把方法当做参数来传递的话,就要用到委托.简单来说委托是一个类型,这个类型可以赋值一个方法的引用. 声明委托: 在C#中使用一个类分两个阶段,首选定义这个类,告诉编译器这个类由什么字段和方法组成的,然后使用这个类实例化对象.在我们使用委托的时候,也需要经过这两个阶段,首先定义委托,告诉编译器我们这个委托可以指向哪些类型的方法,然后,创建该委托的实例. 定义委托的语法如下: delegate void IntMethodInvoker(int x); 定义了一个委托叫做IntMe

(C#) 内置 委托(1)

上篇文章简单介绍了一下什么是委托?但是每次都内定义一个委托,感觉有些麻烦,所以微软为了为人民服务,提出了内置委托,让你直接使用就好. 对于内置委托,最常用的主要有三个,Action<>,Func<>,Predicate<> 对于内置,怎么理解?其实就是少去了定义的过程. 对于Action<>的出现是在.NetFramework2.0的时候出现的,当时还只能够传入4个值,渐渐的在.NetFramework3.0的支持下,出现了Func<>,满足了对

C#常用的内置委托

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks; namespace 内置委托{static class Program { static void Main(string[] args) { } static List<Person> GetPersonList() { return new List<Person

个人总结:匿名委托+内置委托+Lambda表达式

匿名委托+内置委托+Lambda表达式 概要 在实际开发中,项目开发框架不同,用到的技术是不一样的,这里总结一下用Linq开发,ORM之EF开发会大量使用的Lambda表达式; 正文 之前提过.Net有一套扩展在IEumberable<T>泛型接口的扩展方法,本文是从这个基础继续总结; 1.void Action<in T>: 先拿一个ForEach()来讲: public void ForEach(Action<T> action); 这个Action<T>

.NET (二)委托第二讲:内置委托Func

在上一章节中,我们自己声明了一个委托: public delegate bool Cal(int num); 接受int参数,返回bool类型,目的是过滤集合中的 奇数 或者 偶数. .NET 为我们内置了一个泛型委托,用于处理这种情况,省去了自定义的麻烦. public delegate TResult Func<in T, out TResult>(T arg); Func是.NET定义的委托,接受任何参数,并返回自定义类型结果. 我们可以将代码修改为:public static void

关于内置委托的用法

Action委托 static void Main(string[] args) { #region Func<T,TResult>委托示例 //需求:查找整型集合list中大于3的所有元素组成的新集合,并打印出集合元素 List<int> list = new List<int>() { 1, 2, 3, 4, 5 }; //将匿名方法分配给 Func<T,TResult> 委托实例 Func<int, bool> concat1 = dele

CLR环境中内置了几个常用委托(转)

CLR环境中给我们内置了几个常用委托Action. Action<T>.Func<T>.Predicate<T>,一般我们要用到委托的时候,尽量不要自己再定义一 个委托了,就用系统内置的这几个已经能够满足大部分的需求,且让代码符合规范.一.Action Action封装的方法没有参数也没有返回值,声明原型为: 1 public delegate void Action(); 用法如下: public void Alert() { Console.WriteLine(&q

c# 匿名方法(函数) 匿名委托 内置泛型委托 lamada

匿名方法:通过匿名委托 .lamada表达式定义的函数具体操作并复制给委托类型: 匿名委托:委托的一种简单化声明方式通过delegate关键字声明: 内置泛型委托:系统已经内置的委托类型主要是不带返回值的Action<T1,,,,Tn>和带返回值的Func<T1,,,Tn,Tresult> 实例代码 class demoFunc { /// <summary> /// 定义函数单条语句直接用lamada表达式 /// </summary> /// <p

C#中常用的系统内置委托

在公共语言运行时(CLR)环境中系统为我们内置了一些常用的委托,包括Action类的委托.Func类的委托.Predicate<T>委托.Comparison<T>委托等等.以上这些委托的命名空间都是System,所属程序集都是 mscorlib.dll,今天我就来讲一讲这些委托的使用方法. 就像我们自己已定义好的一样,要实现某些功能,我们可以直接利用系统内置委托,实例化它们,而不必显式定义一个新委托并将命名方法分配给该委托.如: public static void Test()