我不确定在C#中是否可以这样做但我希望在带有强类型“发送者”参数的抽象类中有事件。
有我的代码
abstract class Base
{
public degate void MyDelegate(Base sender, object arg);
public event MyDelegate SomeEvent;
protected void RaiseSomeEvent(object arg)
{
if (SomeEvent != null)
SomeEvent(this, arg)
}
}
class Derived : Base
{
// ?
}
var obj = new Derived();
obj += EventHandler;
public void EventHandler(Derived sender, object arg)
{
}
那么可以通过操纵generic where子句来实现吗?
答案 0 :(得分:2)
你绝对可以把它变成通用的 - 但在你给出的情况下,你真的不想这样做。
Base.SomeEvent
没有“知道”(在编译时)它是什么类型 - 所以你不能让它依赖于某种类型参数,它将是“正确的类型”。你可以做一些可怕的事情:
abstract class Base<T> where T : Base
{
delegate void MyDelegate(T sender, object arg);
public event MyDelegate SomeEvent;
protected void RaiseSomeEvent(object arg)
{
if (SomeEvent != null)
SomeEvent((T) this, arg)
}
}
(您可能需要(T) (object) this
才能让编译器满意。)
然后:
class Derived : Base<Derived>
但它变得非常丑陋,没有什么可以阻止这种情况发生:
class Evil : Base<Derived>
此时,当事件被提升时,演员表将失败。
我建议如果您确实希望确定发件人是正确的类型,则忽略sender
参数并捕获您首先用于订阅的变量:
Derived derived = new Derived();
derived.SomeEvent += (ignored, arg) => DoSomething(derived, arg);