我对C#中事件委托的通俗看法

这是我对C#中事件的通俗看法,比较适合初学者(其实我也是初学者)对C#事件的理解,本人因为刚入门,在学习C#的事件原理时,发现很多书上写得很不好理解,不适合初学者,所以我想在这里谈谈我对它的看法,可能不是很准确,如果说得对的,请大家鼓鼓掌,不对的或是不规范的地方,还请高手帮忙更正一下,谢谢了。

在学C#之前,我看过《JAVA编程思想》,还有一些JAVA的入门级的书籍,其中对事件的讲解,总是用事件监听,事件适配器来举例,

所以我就一直认为,在C#中,RUNTIMING会一直监测每个控件的状态,如果有控件的状态发生改变和话,就会触发事件。

后来仔细看了一些例题之后,发现这个想法真的是很傻的。

其实,理解C#的事件原理,必须明白以下一点:

控件属性的改变,在它的类中,是由set来改变的,可以理解为由方法(method)来改变的,而不是简单的赋值。

举个例子来说明:
class shape
{
private int cvalue;
public shape()
{cvalue = 0;}
public int colorvalue
{
set{cvalue = value;}
get{return cvalue;}
}
}

class MainApp
{
static void Main(string[] argvs)
{
shape trigon = new shape();
trigon.colorvalue = 3;
}
}

假设,当trigon的属性colorvalue发生改变时,会激发一个ColorChange事件,如果当colorvalue变化时,我们需要它向用户发送一个信息,例如:MessageBox.Show("The Color is Changed!"),那么,通常做法是给shape定义一个事件(怎么样定义这里就不讲了)ColorValueChange,先假设已定义,所以:
class MainApp
{
static void Main(string[] argvs)
{
shape trigon = new shape();
trigon.ColorChange += EventHandler(this.Shape_ColorValue);
trigon.colorvalue = 3;
}
private void Shape_ColorValueChange(object sender, System.EventArgs e)
{
MessageBox.Show("The Color is Changed!");
}
}
因此,当trigon的ColorValue被改变时,事件会被触发;上面的情况,和下面的代码,在结果上是等效的:
class shape
{
private int cvalue;
public shape()
{cvalue = 0;}
public int colorvalue
{
set{cvalue = value; MessageBox.Show("The Color is Changed!");}
get{return cvalue;}
}
}

class MainApp
{
static void Main(string[] argvs)
{
shape trigon = new shape();
trigon.colorvalue = 3;
}
}
但是,一但我们这样定义一个类,如果shape类的使用者不仅仅是想给用户一个信息,他还想达到其它目的话,这个办法就行不通了,所以C#就有了事件委托这个东东。

我是这样理解事件委托的:委托可以接受一个方法的引用作为参数,然后执行这个方法。

所以,我们只要把MessageBox.Show("The Color is Changed!");换成事件委托就可以了,所以,shape类的使用者想要实现一个操作,他只要把他所要的操作定义成一个方法,再把这个方法通过委托,将其引用传给shape类的实例,让这个实例执行这个方法。

这种理解方法虽然不是很规范,但是,对理解C#的事件委托是很有帮助的,希望高手不要笑话。

下面让我们把shape类完整实现吧(现在就很好理解了):
using System;
namespace WinApp
{
//定义一个事件委托类型,注意不是事件
public delegate void ColorChangeEvent(object sender);
public class shape
{
protected int cvalue;

//根据事件委托类型构造一个事件
public event ColorChangeEvent ColorChange;

public int colorvalue
{
set
{
cvalue = value;
ColorChange(this);//在colorvalue的值发生改变后,触发事件。
}
get
{
return cvalue;
}
}
public shape()
{
cvalue = 0 ;
}

}
}

下面是使用shape类的例子:
.
.
.
.
private shape trigon = new shape();

/*
通过委托,将trigon_ColorChange方法的引用传递给shape的实例,一旦实例中执行了ColorChange,
trigon_ColorChange方法就会被调用
*/
this.trigon.ColorChange += new WinApp.ColorChangeEvent(this.trigon_ColorChange);
.
.
.
private void button1_Click(object sender, System.EventArgs e)
{
this.trigon.colorvalue = 3;
}

private void trigon_ColorChange(object sender)
{
MessageBox.Show("The Color is Changed!");
}
.
.
.

时间: 2024-11-01 16:15:03

我对C#中事件委托的通俗看法的相关文章

深入分析javascript中事件委托机制

随着DOM结构的复杂化和Ajax等动态脚本技术的运用,事件委托自然浮出了水面.jQuery为绑定和委托事件提供了.bind()..live()和.delegate()方法.本文在讨论这几个方法内部实现的基础上,展示它们的优劣势及适用场合. 两个问题 1.元素过多时的性能问题 假设有一个多行多列的表格,我们想让用户单击每个单元格都能看到与其中内容相关的更多信息(比如,通过提示条).为此,可以为每个单元格都绑定click事件: $("info_table td").bind("c

javascript中事件委托和this面试题

JavaScript不仅门槛低,而且是一门有趣.功能强大和非常重要的语言.各行各业的人发现自己最混乱的选择是JavaSscript编程语言.由于有着各种各样的背景,所以不是每个人都对JavaScript及其基本原理有广泛的认识.通常来书,除非你去参加工作面试才会去思考为什么或者怎么做,否则JavaScript只是你工作的内容. 这个系类的目标是深入探讨JavaScript的一些概念和理论.主题来自于 Darcy Clarke的JavaScript典型面试问题列表.希望你不仅仅是为了答案而阅读完这

JavaScript中的事件委托及好处_javascript技巧

1,什么是事件委托:通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却加到别人身上来做,完成这个事件. 也就是:利用冒泡的原理,把事件加到父级上,触发执行效果. 好处呢:1,提高性能. 我们可以看一个例子:需要触发每个li来改变他们的背景颜色. <ul id="ul"> <li>aaaaaaaa</li> <li>bbbbbbbb&l

JavaScript动态添加事件之事件委托_javascript技巧

先给大家讲下什么是事件委托:通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却加到别人身上来做,完成这个事件. 也就是:利用冒泡的原理,把事件加到父级上,触发执行效果. 其所谓的动态添加事件实质就是指js中的事件委托. 我们知道在js中,事件处理只能绑定在当前被选中的元素上,换句话也就是说,事件处理只能绑定在当前文档已经存在的元素上!但是,往往小伙伴们都会遇到一个问题就是,我的元素是后来动态

深入理解C#编程中的组件-事件-委托

编程 在组件编程中对事件的理解是十分重要的,C# 中的"事件"是当对象发生某些有趣的事情时,类向该类的客户提供通知的一种方法.与事件联系最为紧密的,个人认为是委托.委托可以将方法引用封装在委托对象内.为了弄清组件-事件-委托三者的关系,本人用实际的例子来谈 谈小弟的理解. 首先创建一个Windows控件项目,添加如下控件样板. 当事件触发时,会传递一个EventArgs类型的参数给事件处理方法,为了能传递自定义的信息,我们可以创建一个继承于EventArgs的事件参数 类,其定义如下:

eventlistener-javascript中使用事件委托无法获取到event.target

问题描述 javascript中使用事件委托无法获取到event.target <!doctype html><html><head> <title>image's transition</title> <script type=""text/javascript""> window.onload = function(){ var pic_wrapper = document.getEleme

javascript 中的事件委托详解_基础知识

这几天看到一个面试题,大概就是,让你给1000个li都添加一个click事件,应该怎么添加?大多数人第一开始的感觉可能就是,每个li上边都添加一个呗,那要是这样的话,估计面试的时候就会GG了,这里就是撤出了我们的事件冒泡和捕获机制,以及事件委托机制,对于上边这些,我们慢慢来看. 首先说一下事件冒泡和事件捕获机制,事件冒泡是有微软公司提出来的,事件捕获是有网景公司提出来的,当时两家是争论的不可开交,后来w3c也没办法,就采取了折中的方式,事件产生后先捕获后冒泡, 通常,在js中监听事件的方法共有三

JavaScript事件委托的技术原理探讨示例_javascript技巧

如今的JavaScript技术界里最火热的一项技术应该是'事件委托(event delegation)'了.使用事件委托技术能让你避免对特定的每个节点添加事件监听器:相反,事件监听器是被添加到它们的父元素上.事件监听器会分析从子元素冒泡上来的事件,找到是哪个子元素的事件.基本概念非常简单,但仍有很多人不理解事件委托的工作原理.这里我将要解释事件委托是如何工作的,并提供几个纯JavaScript的基本事件委托的例子. 假定我们有一个UL元素,它有几个子元素: 复制代码 代码如下: <ul id=&qu

[unity3d]unity中C#委托的应用

C#中有一种还是挺实用的类型,就是委托类型,这也是初学者比较难理解的类型,我们常常将委托和事件合起来讲,其实他们两是有些区别的,委托(delegate)是一种类型,而事件(Event)是一种实例(委托中的一种).下面我就从参考网上的一个例子,讲解一下unity中C#委托的应用. 我们新建一个脚本,取名TestDelegate.这个主要的功能就是点击中文按钮输出中文名字,点击英文按钮输出英文名字.这里有两个函数分别实现了这两个功能.如果不用委托,可以用if else,switch来实现,相比新手用