• .NET : Func委托和Action委托


    上一篇我们讲到了如何在ASP.NET页面中实现异步任务。我们来回顾一下里面一个特殊的类型:LongTimeTask

    public class LongTimeTask
    {
        public string Result = string.Empty;
        public HelloWorldHandler handler;

        public delegate string HelloWorldHandler();
        public string HelloWorld()
        {
            Thread.Sleep(5000);
            return "Hello,world";
        }

        public IAsyncResult OnBegin(object sender, EventArgs e,
    AsyncCallback cb, object extraData)
        {
            handler = new HelloWorldHandler(this.HelloWorld);
            return handler.BeginInvoke(cb, extraData);

        }

        public void OnEnd(IAsyncResult ar)
        {
            Result = handler.EndInvoke(ar);
        }

        public void OnTimeout(IAsyncResult ar)
        {
            Result = "超时了";
        }
    }

    我们真正要执行是HelloWorld,但是,为了能够异步调用该方法,所以我们定义了一个delegate(委托),上面红色标出的代码就可以看到,这个delegate其实是我们全部代码中的灵魂。

    我这一篇讨论的是:以前我们为了能够调用一个方法,必须比照这个方法定义一个相应的delegate,这个是否能有更好的实现办法呢?

    答案是:有,也就是有通用的delegate了。在.NET Framework 3.5中,提供了两类通用的delegate。

    1. 如果方法有返回值,则使用Func,或者Func<>
    2. 如果方法没有返回值,则使用Action,或者Action<>

    关于这两个委托的详细资料,大家可以参考MSDN的文档

    要使用这两个delegate,必须引用System.Core.dll

    image

    下面来看修改好的代码

    using System;
    using System.Threading;

    namespace WebApplication2
    {
        public class LongTimeTask
        {
            public string Result = string.Empty;
            public Func<string> handler;

            public delegate string HelloWorldHandler();
            public string HelloWorld()
            {
                Thread.Sleep(5000);
                return "Hello,world";
            }

            public IAsyncResult OnBegin(object sender, EventArgs e,
        AsyncCallback cb, object extraData)
            {
               handler = new Func<string>(this.HelloWorld);
                return handler.BeginInvoke(cb, extraData);

            }

            public void OnEnd(IAsyncResult ar)
            {
                Result = handler.EndInvoke(ar);
            }

            public void OnTimeout(IAsyncResult ar)
            {
                Result = "超时了";
            }
        }
    }

    本文由作者:陈希章 于 2009/7/12 20:06:38 发布在:http://www.cnblogs.com/chenxizhang/
    本文版权归作者所有,可以转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
    更多博客文章,以及作者对于博客引用方面的完整声明以及合作方面的政策,请参考以下站点:陈希章的博客中心
  • 相关阅读:
    .NET Core依赖注入集成Dynamic Proxy
    MediatR-进程内的消息通信框架
    03-EF Core笔记之查询数据
    02-EF Core笔记之保存数据
    01-EF Core笔记之创建模型
    EF Core 基础知识
    CQRS+ES项目解析-Equinox
    CQRS+ES项目解析-Diary.CQRS
    不要让事实妨碍好故事:Facebook精准广告产品与硅谷创业揭秘,4星奇书《混乱的猴子》
    会讲故事的前物理学家万维钢解读、推荐过的书24本,好书一半
  • 原文地址:https://www.cnblogs.com/chenxizhang/p/1522073.html
Copyright © 2020-2023  润新知