C# 事件(Event)

  事件(Event) 基本上说是一个用户操作,如按键、点击、鼠标移动等等,或者是一些出现,如系统生成的通知。应用程序需要在事件发生时响应事件。例如,中断。事件是用于进程间通信。

  通过事件使用委托

  事件在类中声明且生成,且通过使用同一个类或其他类中的委托与事件处理程序关联。包含事件的类用于发布事件。这被称为 发布器(publisher) 类。其他接受该事件的类被称为 订阅器(subscriber) 类。事件使用 发布-订阅(publisher-subscriber) 模型。

  发布器(publisher) 是一个包含事件和委托定义的对象。事件和委托之间的联系也定义在这个对象中。发布器(publisher)类的对象调用这个事件,并通知其他的对象。

  订阅器(subscriber) 是一个接受事件并提供事件处理程序的对象。在发布器(publisher)类中的委托调用订阅器(subscriber)类中的方法(事件处理程序)。

  声明事件(Event)

  在类的内部声明事件,首先必须声明该事件的委托类型。例如:

  public delegate void BoilerLogHandler(string status);

  然后,声明事件本身,使用 event 关键字:

  // 基于上面的委托定义事件

  public event BoilerLogHandler BoilerEventLog;

  上面的代码定义了一个名为 BoilerLogHandler 的委托和一个名为 BoilerEventLog 的事件,该事件在生成的时候会调用委托。

  实例 1

  using System;

  namespace SimpleEvent

  {

  using System;

  public class EventTest

  {

  private int value;

  public delegate void NumManipulationHandler();

  public event NumManipulationHandler ChangeNum;

  protected virtual void OnNumChanged()

  {

  if (ChangeNum != null)

  {

  ChangeNum();

  }

  else

  {

  Console.WriteLine("Event fired!");

  }

  }

  public EventTest(int n )

  {

  SetValue(n);

  }

  public void SetValue(int n)

  {

  if (value != n)

  {

  value = n;

  OnNumChanged();

  }

  }

  }

  public class MainClass

  {

  public static void Main()

  {

  EventTest e = new EventTest(5);

  e.SetValue(7);

  e.SetValue(11);

  Console.ReadKey();

  }

  }

  }

  当上面的代码被编译和执行时,它会产生下列结果:

  Event Fired!

  Event Fired!

  Event Fired!

  实例 2

  本实例提供一个简单的用于热水锅炉系统故障排除的应用程序。当维修工程师检查锅炉时,锅炉的温度和压力会随着维修工程师的备注自动记录到日志文件中。

  using System;

  using System.IO;

  namespace BoilerEventAppl

  {

  // boiler 类

  class Boiler

  {

  private int temp;

  private int pressure;

  public Boiler(int t, int p)

  {

  temp = t;

  pressure = p;

  }

  public int getTemp()

  {

  return temp;

  }

  public int getPressure()

  {

  return pressure;

  }

  }

  // 事件发布器

  class DelegateBoilerEvent

  {

  public delegate void BoilerLogHandler(string status);

  // 基于上面的委托定义事件

  public event BoilerLogHandler BoilerEventLog;

  public void LogProcess()

  {

  string remarks = "O. K";

  Boiler b = new Boiler(100, 12);

  int t = b.getTemp();

  int p = b.getPressure();

  if(t > 150 || t < 80 || p < 12 || p > 15)

  {

  remarks = "Need Maintenance";

  }

  OnBoilerEventLog("Logging Info:\n");

  OnBoilerEventLog("Temparature " + t + "\nPressure: " + p);

  OnBoilerEventLog("\nMessage: " + remarks);

  }

  protected void OnBoilerEventLog(string message)

  {

  if (BoilerEventLog != null)

  {

  BoilerEventLog(message);

  }

  }

  }

  // 该类保留写入日志文件的条款

  class BoilerInfoLogger

  {

  FileStream fs;

  StreamWriter sw;

  public BoilerInfoLogger(string filename)

  {

  fs = new FileStream(filename, FileMode.Append, FileAccess.Write);

  sw = new StreamWriter(fs);

  }

  public void Logger(string info)

  {

  sw.WriteLine(info);

  }

  public void Close()

  {

  sw.Close();

  fs.Close();

  }

  }

  // 事件订阅器

  public class RecordBoilerInfo

  {

  static void Logger(string info)

  {

  Console.WriteLine(info);

  }//end of Logger

  static void Main(string[] args)

  {

  BoilerInfoLogger filelog = new BoilerInfoLogger("e:\\boiler.txt");

  DelegateBoilerEvent boilerEvent = new DelegateBoilerEvent();

  boilerEvent.BoilerEventLog += new

  DelegateBoilerEvent.BoilerLogHandler(Logger);

  boilerEvent.BoilerEventLog += new

  DelegateBoilerEvent.BoilerLogHandler(filelog.Logger);

  boilerEvent.LogProcess();

  Console.ReadLine();

  filelog.Close();

  }//end of main

  }//end of RecordBoilerInfo

  }

  当上面的代码被编译和执行时,它会产生下列结果:

  Logging info:

  Temperature 100

  Pressure 12

  Message: O. K

  本文转载自:w3cschool(编辑:雷林鹏 来源:网络)

雷林鹏分享:C# 事件(Event)的更多相关文章

  1. 雷林鹏分享:jQuery EasyUI 数据网格 - 列运算

    jQuery EasyUI 数据网格 - 列运算 在本教程中,您将学习如何在可编辑的数据网格(datagrid)中包含一个运算的列.一个运算列通常包含一些从一个或多个其他列运算的值. 首先,创建一个可 ...

  2. 雷林鹏分享:jQuery EasyUI 数据网格 - 扩展行显示细节

    数据网格(datagrid)可以改变它的视图(view)来显示不同的效果.使用详细视图,数据网格(datagrid)可以在数据行的左边显示展开按钮("+" 或者 "-&q ...

  3. 雷林鹏分享:jQuery EasyUI 数据网格 - 创建子网格

    jQuery EasyUI 数据网格 - 创建子网格 使用数据网格(datagrid)的详细视图,用户可以展开一行来显示附加的详细信息. 任何内容都可以加载作为行详细,子网格也可以动态加载. 本教程将 ...

  4. 雷林鹏分享:jQuery EasyUI 树形菜单 - 树形菜单拖放控制

    jQuery EasyUI 树形菜单 - 树形菜单拖放控制 当在一个应用中使用树(Tree)插件,拖拽(drag)和放置(drop)功能要求允许用户改变节点位置.启用拖拽(drag)和放置(drop) ...

  5. 雷林鹏分享:jQuery EasyUI 插件

    jQuery EasyUI 插件 jQuery EasyUI 提供了用于创建跨浏览器网页的完整的组件集合,包括功能强大的 datagrid(数据网格).treegrid(树形表格). panel(面板 ...

  6. 雷林鹏分享:XML 注意事项

    XML 注意事项 这里列出了您在使用 XML 时应该尽量避免使用的技术. Internet Explorer - XML 数据岛 它是什么?XML 数据岛是嵌入到 HTML 页面中的 XML 数据. ...

  7. 雷林鹏分享: C# 简介

    C# 简介 C# 是一个现代的.通用的.面向对象的编程语言,它是由微软(Microsoft)开发的,由 Ecma 和 ISO 核准认可的. C# 是由 Anders Hejlsberg 和他的团队在 ...

  8. 雷林鹏分享:C# 结构(Struct)

    C# 结构(Struct) 在 C# 中,结构是值类型数据结构.它使得一个单一变量可以存储各种数据类型的相关数据.struct 关键字用于创建结构. 结构是用来代表一个记录.假设您想跟踪图书馆中书的动 ...

  9. 雷林鹏分享:C# 接口(Interface)

    C# 接口(Interface) 接口定义了所有类继承接口时应遵循的语法合同.接口定义了语法合同 "是什么" 部分,派生类定义了语法合同 "怎么做" 部分. 接 ...

随机推荐

  1. hdu5195 二分+线段树+拓扑序

    这题说的给了n个点m条边要求保证是一个有向无环图,可以删除至多k条边使得这个图的拓扑序的字典序最大,我们知道如果我们要排一个点的时候一定要考虑比他大的点是否可以.通过拆边马上拆出来,如果可以拆当然是拆 ...

  2. selinux配置错误实例介绍

    错误原因 配置关闭SELinux,结果误操作 应修改配置文件/etc/selinux/config中的“SELINUX”参数的值, # SELINUX=enforcing  原始配置 SELINUX= ...

  3. SQL学习之SQL注入总结

    Sql注入定义: 就是通过把sql命令插入到web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行的sql命令的目的. sql注入分类: 基于联合查询 基于错误回显 基于盲注,分时间盲 ...

  4. label语句、break语句和continue语句

    label语句 可以在代码中添加标签,以便使用.以下是label语句的语法: label:statement 示例: start: for (var i = 0; i < count; i++) ...

  5. ORM 关系对象映射 基础知识点

    优点: 1.ORM使我们通用的数据库变得更加的简单便捷. 2.可避免新手程序员写sql语句带来的性能问题. 1. 创建单表 2. 创建关键表 1). 一对一 2). 一对多 3). 多对多 创建表的语 ...

  6. awk之match函数

    功能:match函数是用于个性化定制搜索模式. 例子: 文件内容: this is wang ,not wan that is chen, not che this is chen ,and wang ...

  7. 20145307陈俊达《网络对抗》Exp7 网络欺诈技术防范

    20145307陈俊达<网络对抗>Exp7 网络欺诈技术防范 基础问题回答 什么是dns欺骗攻击! 利用dns spoof运行DNS欺骗,如果是请求解析某个域名,dnsspoof会让该域名 ...

  8. 过滤Windows文件名中的非法字符

    转载:http://blog.csdn.net/infoworld/article/details/42033097 场景: 1. 通常生成文件时需要一个文件名,而生成文件名的方式可能是通过用户输入的 ...

  9. Python3.5 MySQL 数据库连接

    Python3.5  MySQL 数据库连接 在本文中介绍 Python3 使用PyMySQL连接数据库,并实现简单的增删改查 为什么使用PyMySQL? PyMySQL是在Pyhton3.x版本中用 ...

  10. goole机器学习视频链接【学习笔记】

    作者:庄泽彬 说明:在youtu上观看的google的机器学习相关的视频,如何fangqiang请自己解决 机器学习简介:https://www.youtube.com/watch?time_cont ...