`
maxwellens
  • 浏览: 12806 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
社区版块
存档分类
最新评论

C#事件机制及响应方法

    博客分类:
  • .Net
阅读更多
C#语言自C/C++演变而来。它是现代、简单、完全面向对象和类型安全的。C#语言是微软公司针对.Net平台才推出来的一门新语言,作为.Net平台的第一语言,它几乎集中了所有关于软件开发和软件工程研究的最新成果。面向对象、类型安全、组件技术、自动内存管理、跨平台异常处理、版本控制、代码安全管理…… 在.NET应用程序开发中,不管是WEB Forms(ASP.NET)还是Windows Forms,都涉及到大量对象的事件响应及处理,比如客户在线提交一份订单、或是在Windows窗口上移动鼠标等都将有事件发生。那么在C#中,是怎样声明事件并为事件添加响应方法的呢?下面的文章对此为大家作了详细的讲述。 原理简介 ;在C#中,一个类可以有域(Fields)、属性(Properties)、方法(Methods)、索引(Indexs)、事件(Events)等成员,其中事件(Events)成员就是用来声明一个类事件的。在类中声明一个事件成员一般采用如下的语法形式:public event 代表名 事件名。

1.委派的实现过程。
首先来看一下委派,委派其实就是方法的传递,并不定义方法的实现。事件其实就是标准化了的委派,为了事件处理过程特制的、稍微专业化一点的组播委派(多点委派)。下面举一个例子,我觉得把委派的例子和事件的例子比较,会比较容易理解。
using System; 
  
class Class1 
{ 
       delegate int MathOp(int i1,int i2); 
       static void Main(string[] args) 
       { 
               MathOp op1=new MathOp(Add); 
               MathOp op2=new MathOp(Multiply); 
               Console.WriteLine(op1(100,200)); 
               Console.WriteLine(op2(100,200)); 
               Console.ReadLine(); 
       } 
       public static int Add(int i1,int i2) 
       { 
               return i1+i2; 
       } 
       public static int Multiply(int i1,int i2) 
       { 
              return i1*i2; 
       } 
} 
 
首先代码定义了一个委托MathOp,其签名匹配与两个函数Add()和Multiply()的签名(也就是其带的参数类型数量相同):
delegate int MathOp(int i1,int i2);
Main()中代码首先使用新的委托类型声明一个变量,并且初始化委托变量.注意,声明时的参数只要使用委托传递的函数的函数名,而不加括号:
MathOp op1=new MathOp(Add);
(或为MathOp op1=new MathOp(Multiply);)
委托传递的函数的函数体:
public static int Add(int i1,int i2) 
{ 
       return i1+i2; 
} 
public static int Multiply(int i1,int i2) 
{ 
      return i1*i2; 
} 
然后把委托变量看作是一个函数名,将参数传递给函数。 Console.WriteLine(op1(100,200));
Console.WriteLine(op2(100,200));
 
 
2.事件的实现过程
using System; 
  
class Class1 
{ 
       static void Main(string[] args) 
       { 
               Student s1=new Student(); 
               Student s2=new Student(); 
               s1.RegisterOK +=new Student.DelegateRegisterOkEvent(Student_RegisterOK); 
               s2.RegisterOK +=new Student.DelegateRegisterOkEvent(Student_RegisterOK); 
               s1.Register(); 
               s2.Register(); 
               Console.ReadLine(); 
       } 
       static void Student_RegisterOK() 
       { 
              Console.WriteLine("Hello"); 
       } 
} 
  
class Student 
{ 
       public delegate void DelegateRegisterOkEvent(); 
       public event DelegateRegisterOkEvent RegisterOK; 
       public string Name; 
       public void Register() 
       { 
              Console.WriteLine("Register Method"); 
              RegisterOK(); 
       } 
} 
在Student类中,先声明了委托DelegateRegisterOkEvent(),然后使用event和要使用的委托类型(前面定义的DelegateRegisterOkEvent委托类型)声明事件RegisterOK(可以看作是委托的一个实例。):
public delegate void DelegateRegisterOkEvent(); 
public event DelegateRegisterOkEvent RegisterOK; 
然后在Main()函数中,实例化Student类,然后s1.RegisterOK事件委托给了Student_RegisterOK 方法。通过“+=”(加等于)操作符非常容易地为.Net对象中的一个事件添加一个甚至多个响应方法;还可以通过非常简单的“-=”(减等于)操作符取消这些响应方法。
然后,当调用s1.Register()时,事件s1.RegisterOK发生。

using System;

class Class1

{
       static void Main(string[] args)
       {
               Student s1=new Student();
               Student s2=new Student();
               s1.RegisterOK +=new Student.DelegateRegisterOkEvent(Student_RegisterOK);
               s2.RegisterOK +=new Student.DelegateRegisterOkEvent(Student_RegisterOK);
               s1.Register();
               s2.Register();
               Console.ReadLine();
       }

       static void Student_RegisterOK()
       {
              Console.WriteLine("Hello");
       }
}

class Student

{
       public delegate void DelegateRegisterOkEvent();
       public event DelegateRegisterOkEvent RegisterOK;
       public string Name;

       public void Register()

       {
              Console.WriteLine("Register Method");
              RegisterOK();
       }
}

  在Student类中,先声明了委托DelegateRegisterOkEvent(),然后使用event和要使用的委托类型(前面定义的DelegateRegisterOkEvent委托类型)声明事件RegisterOK(可以看作是委托的一个实例。):

public delegate void DelegateRegisterOkEvent();

public event DelegateRegisterOkEvent RegisterOK;

  然后在Main()函数中,实例化Student类,然后s1.RegisterOK事件委托给了Student_RegisterOK 方法。通过“+=”(加等于)操作符非常容易地为.Net对象中的一个事件添加一个甚至多个响应方法;还可以通过非常简单的“-=”(减等于)操作符取消这些响应方法。

  然后,当调用s1.Register()时,事件s1.RegisterOK发生。


3.C#中预定义事件处理方式
    学习事件,我觉得最不好理解的就是C#中预定义了事件,使我才开始学习事件时一头雾水。在查了些资料后,终于弄明白了一些,如下:
EventArgs是包含事件数据的类的基类,用于传递事件的细节。
EventHandler是一个委托声明如下(其在.Net类库中如下声明的)
public delegate void EventHandler( object sender , EventArgs e ) 所以,所有形如: 
void 函娄名(object 参数名,EventArgs 参数名);
的函数都可以作为Control类的Click事件响应方法了。如下面所定义的一个事件响应方法:
private void button1_Click(object sender, System.EventArgs e)
参数object sender表示引发事件的对象,(其实这里传递的是对象的引用,如果是button1的click事件则sender就是button1)System.EventArgs e 代表事件的相应信息,如鼠标的x,y值等。
下面我们研究一下Button类看看其中的事件声明,以Click事件为例。
public event EventHandler Click;
这里定义了一个EventHandler类型的事件Click
private void button1_Click(object sender, System.EventArgs e)
{
   ...
}
这是我们和button1_click事件所对应的方法。注意方法的参数符合委托中的签名(既参数列表)。那我们怎么把这个方法和事件联系起来呢,请看下面的代码。
this.button1.Click += new System.EventHandler(this.button1_Click); (其实button1.Click 为System.EventHandler委派的实例事件。与委派中委派实例委托给某一方法非常相似)
把this.button1_Click方法绑定到this.button1.Click事件。
 
 
4.事件的参数的使用。
using System; 
  
class Class1 
{ 
       static void Main() 
       { 
               Student s1=new Student(); 
               s1.Name ="Student1"; 
               Student s2=new Student(); 
               s2.Name ="Student2"; 
              s1.RegisterOK +=new Student.DelegateRegisterOkEvent(Student_RegisterOK); 
               s2.RegisterOK +=new Student.DelegateRegisterOkEvent(Student_RegisterOK); 
  
               //当Register方法一执行,触发RegisterOK事件 
               //RegisterOK事件一触发,然后执行Student_RegisterOK方法 
               s1.Register();   
              s2.Register(); 
              Console.ReadLine(); 
       } 
       static void Student_RegisterOK(RegisterOkArgs e) 
       { 
              Console.WriteLine(e.EventInfo); 
       } 
} 
  
class Student 
{ 
       public delegate void DelegateRegisterOkEvent(RegisterOkArgs e); 
       public event DelegateRegisterOkEvent RegisterOK; 
       public string Name; 
       public void Register() 
       { 
              Console.WriteLine("Register Method"); 
              RegisterOK(new RegisterOkArgs("Student Name: "+Name)); 
       } 
} 
class RegisterOkArgs:EventArgs 
{ 
       public string EventInfo; 
       public RegisterOkArgs(string eventInfo):base() 
       { 
              this.EventInfo =eventInfo; 
       } 
}



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/vsweaver/archive/2006/08/01/1007145.aspx
分享到:
评论

相关推荐

    C#消息循环与响应机制

    你可能通过看书知道了MFC的消息循环和传递机制,但是C#的事件和MFC的消息机制有什么区别和共同点呢?本文档揭示了winform程序的内部消息机制.

    C#TCP服务端+客户端(心跳机制).zip

    基于VS2017 开发,编译直接运行。 自带客户与服务端心跳包验证。 客户端掉线,服务器自动响应。 所有均为事件与封装完全分享。... 客户端消息异常,快速响应事件。 客户端与服务端,调用DOME完全分离。

    c#串口测试程序

    //代码区块当成参数传递的程序代码编写技术,通过此种方法可以直接使用委托来设计事件响应程序 //以下就是你要在主线程上实现的功能,但是有一点要注意,这里不适宜处理过多的方法,因为C#消息机 //制是消息流水...

    CLR.via.C#.(中文第3版)(自制详细书签)Part2

    11.1.3 第三步:定义负责引发事件的方法来通知事件的登记对象 11.1.4 第四步:定义方法将输入转化为期望事件 11.2 编译器如何实现事件 11.3 设计侦听事件的类型 11.4 显式实现事件 第12章 泛型 12.1 ...

    C# Socket心跳包跟图片传输,TCP/IP协议响应Demo供学习之用

    很多人在写Socket的时候会遇到心跳包响应机制跟主线程消息传输机制如何规避而互不影响,本Demo就解决了此问题,而且简单易懂,都有备注,欢迎下载学习之用。

    金旭亮《C#面向对象程序设计》教案_6:委托与事件

    此教案重点介绍.NET平台上的重要技术——委托,以及对建立于委托基础之上的.NET事件响应机制的深入剖析。包括两个29页的PDF文档及数个VS2010示例。前几讲的教案请访问http://bitfan.download.csdn.net/下载,更新...

    C# UDP 异步通信

    C#写的UDP异步通信控制台程序 客户端发送消息,服务器端响应机制 代码中的注释非常详细

    CLR.via.C#.(中文第3版)(自制详细书签)

    11.1.3 第三步:定义负责引发事件的方法来通知事件的登记对象 11.1.4 第四步:定义方法将输入转化为期望事件 11.2 编译器如何实现事件 11.3 设计侦听事件的类型 11.4 显式实现事件 第12章 泛型 12.1 Framework...

    C#微软培训资料

    14.1 C#的继承机制.155 <<page 3>> page begin==================== 14.2 多 态 性 .159 14.3 抽象与密封 .163 14.4 继承中关于属性的一些问题.169 14.5 小 结 .172 第四部分 深入了解 C#.174 第十...

    c#主线程不卡延时函数

    平时我们在做winform开发的时候,有时候需要让程序休眠几秒钟,但是,如果我们直接使用 thread.sleep()函数,页面ui就会停止响应。怎么样解决呢,你可以把页面涉及到表现ui的代码放到一个单线程处理,也可以采用我...

    编程课程+C#基础课程+C#&.NET技术开发+基础系列课程

    - 性能优化技巧:探索异步编程、内存管理和垃圾回收机制,提高应用程序的性能和响应能力。 - 微服务架构实践:了解微服务架构的理念,学习如何设计和实现微服务系统。 - 实战项目开发:从需求分析到部署维护,全程...

    响应式架构 消息模式Actor实现与Scala.Akka应用集成.rar

    其中包括:Actor模型和响应式软件的主要概念、Scala语言的基础知识、Akka框架与Akka集群功能、Actor模型中的通道机制和技术、降低消息源与消息目的地之间耦合性的方式、持久化Actor对象和幂等接收者。附录A中还介绍...

    C# 串口收发异常,偶尔有某个收不到,断点计数都断不到,原因分析(1)

    经了解:C#消息机制是消息流水线响应机,不能同时进行。 C# 数据更新是在Timer,分析:可能是在进行time任务时,不能进行invoke接收任务。之后我打算开个多线程试试或把接收中处理精简看看能不能收到。 private ...

    响应式架构 消息模式Actor实现与Scala.Akka应用集成

    其中包括:Actor模型和响应式软件的主要概念、Scala语言的基础知识、Akka框架与Akka集群功能、Actor模型中的通道机制和技术、降低消息源与消息目的地之间耦合性的方式、持久化Actor对象和幂等接收者。附录A中还介绍...

    C#中事件处理的个人体会

    捕获事件并对其作出响应的对象叫做事件接收方。 在事件通信中,事件发送方类不知道哪个对象或方法将接收到(处理)它引发的事件。所需要的是在源和接收方之间存在一个媒介(或类似指针的机制)。.NET Framework ...

    FTP服务器 C#

    用VS编写的FTP服务器软件,C#网络程序编程学习用。 代码: using System; using System.Collections.Generic; using System.Globalization; using System.IO; using System.Net; using System.Net.Sockets; using ...

    CLR.via.C#.(中文第3版)(自制详细书签)Part1

    11.1.3 第三步:定义负责引发事件的方法来通知事件的登记对象 11.1.4 第四步:定义方法将输入转化为期望事件 11.2 编译器如何实现事件 11.3 设计侦听事件的类型 11.4 显式实现事件 第12章 泛型 12.1 ...

    CLR.via.C#.(中文第3版)(自制详细书签)Part3

    11.1.3 第三步:定义负责引发事件的方法来通知事件的登记对象 11.1.4 第四步:定义方法将输入转化为期望事件 11.2 编译器如何实现事件 11.3 设计侦听事件的类型 11.4 显式实现事件 第12章 泛型 12.1 ...

    Visual.C#2010从入门到精通

    学习以c#的必备书 本书介绍了如何使用Visual C++ 6.0编写Windows应用程序。全书内容全面、结构清晰、由浅入深、注重实用,并结合了大量的实例,以方便读者理解。本书既包含菜单、鼠标、键盘等基本操作,又包含图形...

    MF00142-原型设计器.zip

    响应:设计器提供了事件响应机制,控件之间通过事件和方法的绑定,实现相互调用。 扩展:控件采用注册方式,注册到程序中的控件即可在用户界面中使用。本版本提供 的所有控件都是独立的dll文件;用户可以继承标准...

Global site tag (gtag.js) - Google Analytics