如何解决验证C#事件触发功能的命名
我是C#的新手,我发现了此文档和有关C#中事件的示例:
对我来说,特别是以下几行:
public void DoSomething()
{
// Write some code that does something useful here
// then raise the event. You can also raise an event
// before you execute a block of code.
OnRaiseCustomEvent(new CustomEventArgs("Event triggered"));
}
// Wrap event invocations inside a protected virtual method
// to allow derived classes to override the event invocation behavior
protected virtual void OnRaiseCustomEvent(CustomEventArgs e)
{
// Make a temporary copy of the event to avoid possibility of
// a race condition if the last subscriber unsubscribes
// immediately after the null check and before the event is raised.
EventHandler<CustomEventArgs> raiseEvent = RaiseCustomEvent;
// Event will be null if there are no subscribers
if (raiseEvent != null)
{
// Format the string to send inside the CustomEventArgs parameter
e.Message += $" at {DateTime.Now}";
// Call to raise the event.
raiseEvent(this,e);
}
}
对我来说,这种命名根本没有意义,或者我不了解事件在C#中的工作方式。如果我没看错,则在DoSomething中触发CustomEvent。但是通常onAnything函数会监听事件。您还认为OnRaiseCustomEvent应该命名为RaiseCustomEvent吗?
解决方法
这是c#的命名约定。
您不必同意它,但是您应该熟悉它,我也建议您在代码中使用它。
经验丰富的C#程序员将看到名为rm ./target
的方法,该方法带有名为On<blabla>
的参数或以后缀EventArgs
结尾的任何内容(例如EventArgs
)立即期望此方法引发一个名为<blabla>EventArgs
的事件。
(自然,<blabla>
只是实际名称的占位符)
之所以存在此模式,是因为在继承事件时,引发事件的唯一方法是在声明类型内-如Expression Binding中所述:
...事件是一种特殊的委托类型,只能从声明它们的类中调用。派生类无法直接调用基类中声明的事件。
这就是为什么您需要将<blabla>
方法设置为On<blabla>(BlaBlaEventArgs e)
(除非您的类被声明为protected virtual
)的原因-这样它的派生类将能够引发{{1 }}事件。
官方文档还承认,在此模式下选择的名称(至少有一些)具有误导性-How to raise base class events in derived classes (C# Programming Guide)
EventHandler这个名称可能会引起一些混乱,因为它实际上并不处理事件。
就我个人而言,我认为他们可能为此和sealed
方法选择了更好的名称,但是现在更改它为时已晚。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。