event
关键字用于在发行者类中声明事件。
下面的示例演示如何声明和引发将 EventHandler 用作基础委托类型的事件。 有关演示如何使用泛型 EventHandler<TEventArgs> 委托类型、如何订阅事件以及如何创建事件处理程序方法的完整代码示例,请参见如何:发布符合 .NET Framework 准则的事件。
public class SampleEventArgs { public SampleEventArgs(string s) { Text = s; } public String Text {get; private set;} // readonly } public class Publisher { // Declare the delegate (if using non-generic pattern). public delegate void SampleEventHandler(object sender, SampleEventArgs e); // Declare the event. public event SampleEventHandler SampleEvent; // Wrap the event in a protected virtual method // to enable derived classes to raise the event. protected virtual void RaiseSampleEvent() { // Raise the event by using the () operator. if (SampleEvent != null) SampleEvent(this, new SampleEventArgs("Hello")); } }
事件是特殊类型的多路广播委托,仅可从声明它们的类或结构(发行者类)中调用。 如果其他类或结构订阅了该事件,则当发行者类引发该事件时,会调用其事件处理程序方法。 有关更多信息和代码示例,请参见事件 和委托。
事件可标记为 public、private、protected、internal 或 protected
internal
。 这些访问修饰符定义类的用户访问事件的方式。 有关更多信息,请参见 访问修饰符。
下面的关键字可应用于事件。
关键字
说明 | 更多信息 | |
---|---|---|
static | 即使类没有实例,调用方也能在任何时候使用该事件。 | 静态类和静态类成员 |
virtual | 允许派生类通过使用 override 关键字来重写事件行为。 | 继承 |
sealed | 指定对于派生类它不再属虚拟性质。 | |
abstract | 编译器不会生成 add 和 remove 事件访问器块,因此派生类必须提供自己的实现。 |
通过使用 static 关键字,可以将事件声明为静态事件。 即使类没有任何实例,调用方也能在任何时候使用静态事件。 有关更多信息,请参见 静态类和静态类成员。
通过使用 virtual 关键字,可以将事件标记为虚拟事件。 这样,派生类就可以通过使用 override 关键字来重写事件行为。 有关更多信息,请参见 继承。 重写虚事件的事件也可以为 sealed,以表示其对于派生类不再是虚事件。 最后,可以将事件声明为 abstract,这意味着编译器不会生成 add
和 remove
事件访问器块。 因此派生类必须提供其自己的实现。
备注:转自:https://msdn.microsoft.com/zh-cn/library/8627sbea.aspx
****************************
事件:
类或对象可以通过事件向其他类或对象通知发生的相关事情。 发送(或引发)事件的类称为“发行者”,接收(或处理)事件的类称为“订户”。
在典型的 C# Windows 窗体或 Web 应用程序中,可订阅由按钮和列表框等控件引发的事件。 可以使用 Visual C# 集成的开发环境 (IDE) 来浏览控件发布的事件,并选择想要处理的事件。 IDE 将自动添加空白事件处理程序方法和订阅该事件的代码。 有关详细信息,请参阅如何:订阅和取消订阅事件。
事件具有以下属性:
发行者确定何时引发事件;订户确定对事件作出何种响应。
一个事件可以有多个订户。 订户可以处理来自多个发行者的多个事件。
没有订户的事件永远也不会引发。
事件通常用于表示用户操作,例如单击按钮或图形用户界面中的菜单选项。
当事件具有多个订户时,引发该事件时会同步调用事件处理程序。 若要异步调用事件,请参阅 Calling Synchronous Methods Asynchronously。
在 .NET Framework 类库中,事件基于 EventHandler 委托和 EventArgs 基类。
有关详细信息,请参见:
备注:转自https://msdn.microsoft.com/zh-cn/library/awbftdfh.aspx
转载于:https://blog.51cto.com/jiaojusuimu/1877277