码迷,mamicode.com
首页 > Windows程序 > 详细

【转】C# 委托(Func、Action)

时间:2020-04-09 12:25:17      阅读:79      评论:0      收藏:0      [点我收藏+]

标签:ret   fir   first   类型   方便   根据   lse   一个   return   

原文地址:
https://cloud.tencent.com/developer/article/1335104

1、Func 用法 (封装方法,传入参数, 有返回值)

Func<in T1, in T2, ..., out TResult> (T1, T2, ...)  

封装一个方法,该方法有 (0 /1/2/3  ... 16)个参数,且返回由 TResult 参数指定的值的类型。

 

public static void Main()
        {
            // 方法一: Func 相当于系统内置的 委托
            Func<int, int, string> method = Calculate;

            // 方法二: 调用 Lambda 方法实现, 更简洁
            Func<int, int, string> method_1 = (x, y) =>
            {
                int val = x + y;
                return string.Format("the calculate {0} plus {1} result is: {2}", x, y, val);
            };

            Console.WriteLine(method(3, 5));
            Console.WriteLine(method_1(10, 18));
            Console.ReadLine();
        }


        public static string Calculate(int x, int y)
        {
            int val = x + y;
            return string.Format("the calculate {0} plus {1} result is: {2}", x, y, val);
        }

 

2、Action 用法 (封装一个方法, 传入参数, 无返回值)

 Action<T1, T2, T3, ...>(t1, t2, t3 ...)

封装一个方法, 该方法传入 (0/1/2 ...) 个参数, 且不返回值。

 public static void Main()
        {
            Method_First("Hi, Here!");
            Method_First("Hi, There!");

            Console.ReadLine();
        }

        private static void Method_First(string y)
        {
            Action<string> method;
            method = x => { Console.WriteLine("the input message is: {0}", x); };
            method(y);
        }

        private static void Method_Sec(string y)
        {
            Action<string> method = x => { Console.WriteLine("the input message is : {0}", x); };
            method(y);
        }

 

3. 委托的使用

讲了两种不同情况的委托, 那么什么时候使用委托呢?

根据官方文档,在以下情况下,请使用委托:

  • 当使用事件设计模式时。
  • 当封装静态方法可取时。
  • 当调用方不需要访问实现该方法的对象中的其他属性、方法或接口时。
  • 需要方便的组合。
  • 当类可能需要该方法的多个实现时。

4. 在 Task 使用委托

Task 表示一个异步操作。

public static void Main()
        {
            // 启动方法1
            Task t = Task.Run(() => 
            {
                Thread.Sleep(1000);
                Console.WriteLine("First task finished time is:{0}", DateTime.Now.ToString());
            });


            // 方法2
            Task t_2 = Task.Factory.StartNew(() => {
                Thread.Sleep(2000);
                Console.WriteLine("second task finished time is:{0}", DateTime.Now.ToString());
            });


            // 方法 3
            Action action = () =>
            {
                Thread.Sleep(3000);
                Console.WriteLine("third task finished time is:{0}", DateTime.Now.ToString());
            };
            Task.Factory.StartNew(action).ContinueWith(thirdTask =>
            {
                if (thirdTask.IsCompleted)
                {
                    Console.WriteLine("the third task has finished");
                }
                else if (thirdTask.IsFaulted)
                {
                    Console.WriteLine(thirdTask.Exception);
                }
            });

            Console.WriteLine("main thread has end:{0}",DateTime.Now.ToString() );

            Console.ReadKey();
        }

运行结果如下 : 

main thread has end:2018-03-04 22:03:39

First task finished time is:2018-03-04 22:03:40

second task finished time is:2018-03-04 22:03:41

third task finished time is:2018-03-04 22:03:42

the third task has finished

 

【转】C# 委托(Func、Action)

标签:ret   fir   first   类型   方便   根据   lse   一个   return   

原文地址:https://www.cnblogs.com/louiszh/p/12665828.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!