在C#中,定义事件、委托、委托方法可以使用类库内的EventHandler泛型委托来定义事件、并根据该泛型委托定义实现方法;

同样您也可以自定义委托 来定义事件以及 根据自定义的委托来定义实现事件的方法方法   :

在开始之前,我还是要介绍一下什么是事件,以及“事件”“事件的实现”的区别:

什么是事件?

在C#中,事件就是一个宽泛的、无具体实现的事情,事件是宽泛的、只代表概念而不代表实现,具体的事件触发是通过委托调用实现方法来。

什么是EventArgs类?有什么用?

EventArgs类主要作用在于:在事件触发时,向实现的方法内传递参数,并在事件实现的方法内进行调用或者付值;当执行完事件触发后,定义事件的类就可以通过EventArgs取出被修改得值了;如果没什么好传递并付值的东西,就定义一个基类或者一个null。

1,使用EventHandler泛型委托来实现事件:

a,无返回值的事件调用:

第一步,定义一个委托,下面使用的是系统定义的泛型委托类:EventHandler<>

[Serializable]
    public delegate void EventHandler<TEventArgs>(object sender, TEventArgs e);其中TEventArgs为泛化类型;

-----------------------------------------------------------------------------------------------------------------

第二步,定义TEventArgs 为 ValidationEventArgs,下面是该类的代码:

namespace Microsoft.VisualStudio.TestTools.WebTesting
{
    // 摘要:
    //     为 Microsoft.VisualStudio.TestTools.WebTesting.WebTestRequest.ValidateResponse
    //     事件提供数据。
    public class ValidationEventArgs : EventArgs
    {
        // 摘要:
        //     获取或设置一个值,该值指示请求是否通过验证。
        //
        // 返回结果:
        //     如果请求通过验证,则为 true;否则为 false。
        public bool IsValid { get; set; }
        //
        // 摘要:
        //     获取或设置描述验证尝试的消息。
        //
        // 返回结果:
        //     获取指示是否发生验证的值,或者获取描述所引发异常的消息。
        public string Message { get; set; }
        //
        // 摘要:
        //     获取 Microsoft.VisualStudio.TestTools.WebTesting.WebTestRequest,它生成已验证的响应。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.WebTestRequest 对象。
        public WebTestRequest Request { get; }
        //
        // 摘要:
        //     获取所验证的 Microsoft.VisualStudio.TestTools.WebTesting.WebTestResponse。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.WebTestResponse 对象。
        public WebTestResponse Response { get; }
        //
        // 摘要:
        //     获取当前验证级别。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.ValidationLevel 枚举值。
        public ValidationLevel ValidationLevel { get; }
        //
        // 摘要:
        //     获取 Web 测试,该测试包含触发了验证事件的请求。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.WebTest 对象。
        public WebTest WebTest { get; }
    }
}

-----------------------------------------------------------------------------------------------------------------

第三步,定义事件的实现方法:在事件所在类内,或者其他类中:例如:

public override void Validate(object sender, ValidationEventArgs e)
        {
            e.IsValid = false;
            if (!IsNullorEmpty())
            {
                int Eresult = (int)_sqlUtil3.ExecuteSql(_sqlInfo);
                if (_sqlInfo.TestType.ToLower().Contains("negitive"))
                {
                    if (Eresult == 0)
                    {
                        e.IsValid = false;
                    }
                }
                else if (_sqlInfo.TestType.ToLower().Contains("positive"))
                {
                    if (Eresult == 0)
                    {
                        e.IsValid= true;
                    }
                }
            }
        }

-----------------------------------------------------------------------------------------------------------------

第四步,定义一个触发事件的类并定义事件为委托类型,即事件的类型(委托类型):

public class TouchClass

{

   public event EventHanlder<ValidationEventArgs>(事件的类型为EventHanlder<ValidationEventArgs>委托类型) DataEvent;

public WebTest_Sql      _webTeset_sql = new WebTest_Sql(); //实例化事件所在的类,一便调用事件使用;

   DataEvent +=   EventHanlder<ValidationEventArgs>(_webTeset_sql.Validate);//将事件与方法绑定,注意此处并未执行调用方法,只是将事件与方法做了绑定;

DataEvent(this,ValidationEventArgs); 或者DataEvent.invoke(this,ValidationEventArgs)//事件的执行,注意:这才是事件的执行语句。

}

-----------------------------------------------------------------------------------------------------------------

b,有返回值的事件调用:

第一步,定义一个委托,下面使用的是系统定义的泛型委托类:EventHandler<>

[Serializable]
    public delegate string EventHandler<TEventArgs>(object sender, TEventArgs e);其中TEventArgs为泛化类型;

-----------------------------------------------------------------------------------------------------------------

第二步,定义TEventArgs 为 ValidationEventArgs,下面是该类的代码:

namespace Microsoft.VisualStudio.TestTools.WebTesting
{
    // 摘要:
    //     为 Microsoft.VisualStudio.TestTools.WebTesting.WebTestRequest.ValidateResponse
    //     事件提供数据。
    public class ValidationEventArgs : EventArgs
    {
        // 摘要:
        //     获取或设置一个值,该值指示请求是否通过验证。
        //
        // 返回结果:
        //     如果请求通过验证,则为 true;否则为 false。
        public bool IsValid { get; set; }
        //
        // 摘要:
        //     获取或设置描述验证尝试的消息。
        //
        // 返回结果:
        //     获取指示是否发生验证的值,或者获取描述所引发异常的消息。
        public string Message { get; set; }
        //
        // 摘要:
        //     获取 Microsoft.VisualStudio.TestTools.WebTesting.WebTestRequest,它生成已验证的响应。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.WebTestRequest 对象。
        public WebTestRequest Request { get; }
        //
        // 摘要:
        //     获取所验证的 Microsoft.VisualStudio.TestTools.WebTesting.WebTestResponse。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.WebTestResponse 对象。
        public WebTestResponse Response { get; }
        //
        // 摘要:
        //     获取当前验证级别。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.ValidationLevel 枚举值。
        public ValidationLevel ValidationLevel { get; }
        //
        // 摘要:
        //     获取 Web 测试,该测试包含触发了验证事件的请求。
        //
        // 返回结果:
        //     一个 Microsoft.VisualStudio.TestTools.WebTesting.WebTest 对象。
        public WebTest WebTest { get; }
    }
}

-----------------------------------------------------------------------------------------------------------------

第三步,定义事件的实现方法:在事件所在类内,或者其他类中:例如:

public override string Validate(object sender, ValidationEventArgs e)
        {
            e.IsValid = false;
            if (!IsNullorEmpty())
            {
                int Eresult = (int)_sqlUtil3.ExecuteSql(_sqlInfo);
                if (_sqlInfo.TestType.ToLower().Contains("negitive"))
                {
                    if (Eresult == 0)
                    {
                        e.IsValid = false;
                    }
                }
                else if (_sqlInfo.TestType.ToLower().Contains("positive"))
                {
                    if (Eresult == 0)
                    {
                        e.IsValid= true;
                    }
                }
            }
        }

-----------------------------------------------------------------------------------------------------------------

第四步,定义一个触发事件的类并定义事件为委托类型,即事件的类型(委托类型):

public class TouchClass

{

   public event EventHanlder<ValidationEventArgs>(事件的类型为EventHanlder<ValidationEventArgs>委托类型) DataEvent;

public WebTest_Sql     _webTeset_sql = new WebTest_Sql(); //实例化事件所在的类,一便调用事件使用;

   DataEvent +=   EventHanlder<ValidationEventArgs>(_webTeset_sql.Validate);//将事件与方法绑定,注意此处并未执行调用方法,只是将事件与方法做了绑定;

string ss = DataEvent(this,ValidationEventArgs); 或者string ss = DataEvent.invoke(this,ValidationEventArgs)//事件的执行,注意:这才是事件的执行语句。

}

事件、委托、委托方法的总结(使用EventHandler<>)的更多相关文章

  1. 委托-异步调用-泛型委托-匿名方法-Lambda表达式-事件【转】

    1. 委托 From: http://www.cnblogs.com/daxnet/archive/2008/11/08/1687014.html 类是对象的抽象,而委托则可以看成是函数的抽象.一个委 ...

  2. 委托、Lambda表达式、事件系列04,委托链是怎样形成的, 多播委托, 调用委托链方法,委托链异常处理

    委托是多播委托,我们可以通过"+="把多个方法赋给委托变量,这样就形成了一个委托链.本篇的话题包括:委托链是怎样形成的,如何调用委托链方法,以及委托链异常处理. □ 调用返回类型为 ...

  3. C#基础精华07(委托事件,委托的使用,匿名方法)

    1.委托概述 委托是一种数据类型,像类一样(可以声明委托类型变量).方法参数可以是int.string.类类型 void M1(int n){  } √ void M2(string s){  } √ ...

  4. 委托、事件、匿名方法、Lambda

    一.委托(delegate)     定义:public delegate  void/类型  DefinedDelegate(参数1,参数2...) 委托是类型安全的. 委托实例:DefinedDe ...

  5. 原生js事件委托(事件代理)方法扩展

    原生js事件委托(事件代理)方法扩展: 通过Node底层原型扩展委托方法 /** * 事件委托方法 * @param eventName {string}:事件名称,如'click' * @param ...

  6. c#事件与委托

    C#.net 目录(?)[-] 将方法作为方法的参数 将方法绑定到委托 事件的由来 事件和委托的编译代码 委托事件与Observer设计模式 范例说明 Observer设计模式简介 实现范例的Obse ...

  7. 《C#高级编程》学习笔记------C#中的事件和委托

    本文转载自张子阳 目录 委托的作用 将方法绑定到委托 事件的来由 Observer设计模式 .Net Framework中的委托与事件   引言 委托 和 事件在 .Net Framework中的应用 ...

  8. 每天进步一点--c#基础巩固,事件、委托

    要想技术有所提高,就是把有些问题真正的弄懂弄明白,我从事C#开发两年了,一直对事件委托等概念一知半解,有时候博客园上看看别的大牛的文章,看看懂了就过去了,时间长了又忘了,真正理解还是要自己动手弄些例子 ...

  9. Unity C# 多态 委托 事件 匿名委托 Lambda表达式 观察者模式 .NET 框架中的委托和事件

    一.多态 里氏替换原则: 任何能用基类的地方,可以用子类代替,反过来不行.子类能够在基类的基础上增加新的行为.面向对象设计的基本原则之一. 开放封闭原则: 对扩展开放,意味着有新的需求或变化时,可以对 ...

随机推荐

  1. Chapter 3: Connector(连接器)

    一.概述 Tomcat或者称之为Catalina(开发名称),可以简化为两个主要的模块,如下图: 多个Connector关联一个Container.之所以需要多个Connector,是为了处理多种协议 ...

  2. C语言快速排序

    复习快速排序,用C语言实现: #include <stdio.h> int quicksort(int begin, int end, int a[], int len); void ma ...

  3. 自定义UIAlertView

    You can change accessoryView to any own customContentView in a standard alert view in iOS7 [alertVie ...

  4. ios 从网络上获取图片并在UIImageView中显示

    ios 从网络上获取图片   -(UIImage *) getImageFromURL:(NSString *)fileURL { NSLog(@"执行图片下载函数"); UIIm ...

  5. BZOJ 1600 建造栅栏

    O(N)分成1,2与3,4两部分搞一搞. #include<iostream> #include<cstdio> #include<cstring> #includ ...

  6. simple grammer

    <?phpecho strlen("Hello world!"); // outputs 12?> <?phpecho str_word_count(" ...

  7. lua元表和元方法 《lua程序设计》 13章 读书笔记

    lua中每个值都有一个元表,talble和userdata可以有各自独立的元表,而其它类型的值则共享其类型所属的单一元表.lua在创建table时不会创建元表. t = {} print(getmet ...

  8. ASP.NET定制简单的错误处理页面

    通常Web应用程序在发布后,为了给用户一个友好界面和使用体验,都会在错误发生时跳转至一个自定义的错误页面,而不是ASP.net向用户暴露出来的详细的异常列表. 简单的错误处理页面可以通过web.con ...

  9. 前端学习资源(CSS+HTML5)

    CSS CSS | MDN CSS参考手册 CSS探索之旅 Web前端实验室 STYLESHEETS CSS3中的content字符编码 Font Awesome, 一套绝佳的图标字体库和CSS框架 ...

  10. The Hidden Pitfalls of AsyncTask

    http://logc.at/2011/11/08/the-hidden-pitfalls-of-asynctask/