namespace Contacts
{
//定义委托,它定义了能够表明的方法的类型
public delegate void GreetingDelegate(string name);html
//新建的GreetingManager类
public class GreetingManager
{
public event GreetingDelegate delegate1;
public void GreetPeople(string name,GreetingDelegate delegate1)
{
delegate1(name);
}
}函数
class Program1
{
private static void EnglishGreeting(string name)
{
MessageBox.Show("Morning, " + name);
}this
private static void ChineseGreeting(string name)
{
MessageBox.Show("早上好, " + name);
}spa
public static void RK()
{
GreetingManager gm = new GreetingManager();
gm.delegate1 += EnglishGreeting;
gm.delegate1 += ChineseGreeting;
gm.GreetPeople("菠萝粥");
}
}
}.net
总结:事件与委托困扰我很久了,每次都没有耐心看完,最近一段时间一直在看书写刷题,耐下性子把这章看完了,没怎么理解,百度查的博客,感谢http://www.tracefact.net/tech/009.html 张子阳的分享,让我对知识点有了初步的了解,就是不知道何时使用委托,哈哈哈server
一:委托htm
1.委托也是一个类,因此在命名空间下声明就行,使用关键字delegate声明委托,如对象
public delegate void GreetingDelegate(string name);继承
委托的返回值和参数须要根据绑定的方法的返回值与参数相同事件
2.建立委托类型变量,GreetingDelegate delegate1; 给委托绑定委托方法,
delegate1 = EnglishGreeting;
delegate1 += ChineseGreeting;
第一次“=”至关于实例化委托,“+=”是绑定方法,或直接GreetingDelegate delegate1 = new GreetingDelegate(EnglishGreeting);delegate1 += ChineseGreeting;
3.调用委托:delegate("菠萝粥"),委托就是把方法当作参数进行传递,而后直接使用委托变脸就能够了
二:事件
1.委托理解了,事件就容易不少了,建立委托类型变量的事件,public event GreetingDelegate delegate1;
delegate1 += EnglishGreeting;delegate1 += ChineseGreeting;
使用事件,就是能使用“+=”或者“-=”了,事件至关于封装委托类型变量,跟委托变量同样使用
三:
1.委托类型的名称都应该以EventHandler结束。
2.事件的命名为 Event结束。
--------------------------------------------------符合规范.net规范实例----------------------------------
using System;
using System.Collections.Generic;
using System.Text;
namespace Delegate
{
// 热水器
public class Heater
{
private int temperature;
public string type = "RealFire 001"; // 添加型号做为演示
public string area = "China Xian"; // 添加产地做为演示
//声明委托
public delegate void BoiledEventHandler(Object sender, BoiledEventArgs e);
public event BoiledEventHandler Boiled; //声明事件
// 定义BoiledEventArgs类,传递给Observer所感兴趣的信息
public class BoiledEventArgs : EventArgs
{
public readonly int temperature;
public BoiledEventArgs(int temperature)
{
this.temperature = temperature;
}
}
// 能够供继承自 Heater 的类重写,以便继承类拒绝其余对象对它的监视
protected virtual void OnBoiled(BoiledEventArgs e)
{
if (Boiled != null)
{ // 若是有对象注册
Boiled(this, e); // 调用全部注册对象的方法
}
}
// 烧水。
public void BoilWater()
{
for (int i = 0; i <= 100; i++)
{
temperature = i;
if (temperature > 95)
{
//创建BoiledEventArgs 对象。
BoiledEventArgs e = new BoiledEventArgs(temperature);
OnBoiled(e); // 调用 OnBolied方法
}
}
}
}
// 警报器
public class Alarm
{
public void MakeAlert(Object sender, Heater.BoiledEventArgs e)
{
Heater heater = (Heater)sender; //这里是否是很熟悉呢?
//访问 sender 中的公共字段
Console.WriteLine("Alarm:{0} - {1}: ", heater.area, heater.type);
Console.WriteLine("Alarm: 嘀嘀嘀,水已经 {0} 度了:", e.temperature);
Console.WriteLine();
}
}
// 显示器
public class Display
{
public static void ShowMsg(Object sender, Heater.BoiledEventArgs e)
{ //静态方法
Heater heater = (Heater)sender;
Console.WriteLine("Display:{0} - {1}: ", heater.area, heater.type);
Console.WriteLine("Display:水快烧开了,当前温度:{0}度。", e.temperature);
Console.WriteLine();
}
}
class Program
{
static void Main()
{
Heater heater = new Heater();
Alarm alarm = new Alarm();
heater.Boiled += alarm.MakeAlert; //注册方法
heater.Boiled += (new Alarm()).MakeAlert; //给匿名对象注册方法
heater.Boiled += new Heater.BoiledEventHandler(alarm.MakeAlert); //也能够这么注册
heater.Boiled += Display.ShowMsg; //注册静态方法
heater.BoilWater(); //烧水,会自动调用注册过对象的方法
}
}
}