事件、委托、委托方法的总结(使用EventHandler<>)
在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<>)的更多相关文章
- 委托-异步调用-泛型委托-匿名方法-Lambda表达式-事件【转】
1. 委托 From: http://www.cnblogs.com/daxnet/archive/2008/11/08/1687014.html 类是对象的抽象,而委托则可以看成是函数的抽象.一个委 ...
- 委托、Lambda表达式、事件系列04,委托链是怎样形成的, 多播委托, 调用委托链方法,委托链异常处理
委托是多播委托,我们可以通过"+="把多个方法赋给委托变量,这样就形成了一个委托链.本篇的话题包括:委托链是怎样形成的,如何调用委托链方法,以及委托链异常处理. □ 调用返回类型为 ...
- C#基础精华07(委托事件,委托的使用,匿名方法)
1.委托概述 委托是一种数据类型,像类一样(可以声明委托类型变量).方法参数可以是int.string.类类型 void M1(int n){ } √ void M2(string s){ } √ ...
- 委托、事件、匿名方法、Lambda
一.委托(delegate) 定义:public delegate void/类型 DefinedDelegate(参数1,参数2...) 委托是类型安全的. 委托实例:DefinedDe ...
- 原生js事件委托(事件代理)方法扩展
原生js事件委托(事件代理)方法扩展: 通过Node底层原型扩展委托方法 /** * 事件委托方法 * @param eventName {string}:事件名称,如'click' * @param ...
- c#事件与委托
C#.net 目录(?)[-] 将方法作为方法的参数 将方法绑定到委托 事件的由来 事件和委托的编译代码 委托事件与Observer设计模式 范例说明 Observer设计模式简介 实现范例的Obse ...
- 《C#高级编程》学习笔记------C#中的事件和委托
本文转载自张子阳 目录 委托的作用 将方法绑定到委托 事件的来由 Observer设计模式 .Net Framework中的委托与事件 引言 委托 和 事件在 .Net Framework中的应用 ...
- 每天进步一点--c#基础巩固,事件、委托
要想技术有所提高,就是把有些问题真正的弄懂弄明白,我从事C#开发两年了,一直对事件委托等概念一知半解,有时候博客园上看看别的大牛的文章,看看懂了就过去了,时间长了又忘了,真正理解还是要自己动手弄些例子 ...
- Unity C# 多态 委托 事件 匿名委托 Lambda表达式 观察者模式 .NET 框架中的委托和事件
一.多态 里氏替换原则: 任何能用基类的地方,可以用子类代替,反过来不行.子类能够在基类的基础上增加新的行为.面向对象设计的基本原则之一. 开放封闭原则: 对扩展开放,意味着有新的需求或变化时,可以对 ...
随机推荐
- leetcode 229 Majority Element II
这题用到的基本算法是Boyer–Moore majority vote algorithm wiki里有示例代码 1 import java.util.*; 2 public class Majori ...
- Ubuntu虚机中SVN连接出错,虚机本机可正常CO,CIN,解决方法
Ubuntu虚机中SVN连接出错,虚机本机可正常CO,CIN,外面机器无法正常连接. 解决: 虚机换个IP即可正常连接,原因不明,有可能为公司网管对该IP做了某些限制. PS:VMware中只需将网络 ...
- Ubuntu下Eclipse中文乱码问题解决(转)
Ubuntu下Eclipse中文乱码问题解决 把Windows下的工程导入到了Linux下Eclipse中,由于以前的工程代码,都是GBK编码的(Windows下的Eclipse 默认会去读取系统的编 ...
- 要学JavaScript!进来看吧,反正不花钱!~
有一段时间没有更新自己的博客了,今天终于可以抽出时间和大家分享一下关于JavaScript了.有很多朋友在问我没有接触过会不会很难,不好理解 其实JavaScript的基本语法和Java的基本语法很相 ...
- Minimum Inversion Number_线段树||树状数组
Problem Description The inversion number of a given number sequence a1, a2, ..., an is the number of ...
- 第一个Sprint冲刺第八天
讨论成员:邵家文.李新.朱浩龙.陈俊金 讨论地点:宿舍 解决问题:计分问题 燃尽图
- xcrun: error: active developer path ("/Volumes/Xcode/Xcode6-Beta.app/Contents/Developer") does not exist, use xcode-select to change
When using MacOS with xcode6.4, i always meet these error: xcrun: error: active developer path (&quo ...
- UDP 打洞 原理解释
终于找到了一份满意的UDP打洞原理解释,附上正文,自己整理了一下源码 3.3. UDP hole punching UDP打洞技术 The third technique, and the one o ...
- pstack使用和原理
前言: 最近小组在组织<<深入剖析Nginx>>的读书会, 里面作者提到了pstack这个工具. 之前写JAVA程序, 对jstack这个工具, 非常的喜欢, 觉得很有用. 于 ...
- 02java语法基础问题总结
S和t引用的不是同一个对象 不是原始数据类型 结论: 枚举类型是引用类型,枚举不属于原始数据类型.它的每一个具体值都引用一个特定的对象. 2. 以下代码的输出结果是什么? int X=100; int ...