事件是 C# 结构中的吗?
Are Events in C# structs?
所以我有一个 EventHandlers 字典,但我发现当我在将键值对添加到字典之前附加到一个事件时,一切正常。但是如果我添加键值对然后更新事件处理程序的值,字典不会更新。
public static event EventHandler TestEvent;
private static Dictionary<int, EventHandler> EventMapping = new Dictionary<int, EventHandler>();
//TestEvent += GTKWavePipeClient_TestEvent;
EventMapping.Add(0, TestEvent);
TestEvent += GTKWavePipeClient_TestEvent;
//test event is non null now. keyvaluepair in EventMapping has a value of null
像 EventHandler
这样的委托类型是 不可变的 类型。当您使用赋值 (=
) 或复合赋值 (+=
) 时,将创建一个新实例。
字典保留旧实例。
委托类型是引用类型,但这里重要的是它们的不变性。
当您有 event
时,+=
语法的使用甚至不是赋值。它是对 add
访问器或事件的调用。它将以线程安全的方式重新分配支持字段(新实例)。
请记住,您可以自己编写事件访问器。例如:
public static event EventHandler TestEvent
{
add
{
lock (lockObj)
{
EventHandler oldDel;
if (EventMapping.TryGetValue(0, out oldDel))
EventMapping[0] = oldDel + value;
else
EventMapping.Add(0, value);
}
}
remove
{
lock (lockObj)
{
EventHandler oldDel;
if (EventMapping.TryGetValue(0, out oldDel))
EventMapping[0] = oldDel - value;
}
}
}
private static readonly object lockObj = new object();
private static Dictionary<int, EventHandler> EventMapping = new Dictionary<int, EventHandler>();
有了这个代码,当你去的时候:
TestEvent += GTKWavePipeClient_TestEvent;
您的 add
访问器被调用时 "implicit" 参数 EventHandler value
设置为 GTKWavePipeClient_TestEvent
。
委托是不可变的。您在调用 += 附加事件时将新对象分配给 TestEvent 。因此,在您的非工作场景中,字典中的对象与具有附加事件的对象不同。
所以我有一个 EventHandlers 字典,但我发现当我在将键值对添加到字典之前附加到一个事件时,一切正常。但是如果我添加键值对然后更新事件处理程序的值,字典不会更新。
public static event EventHandler TestEvent;
private static Dictionary<int, EventHandler> EventMapping = new Dictionary<int, EventHandler>();
//TestEvent += GTKWavePipeClient_TestEvent;
EventMapping.Add(0, TestEvent);
TestEvent += GTKWavePipeClient_TestEvent;
//test event is non null now. keyvaluepair in EventMapping has a value of null
像 EventHandler
这样的委托类型是 不可变的 类型。当您使用赋值 (=
) 或复合赋值 (+=
) 时,将创建一个新实例。
字典保留旧实例。
委托类型是引用类型,但这里重要的是它们的不变性。
当您有 event
时,+=
语法的使用甚至不是赋值。它是对 add
访问器或事件的调用。它将以线程安全的方式重新分配支持字段(新实例)。
请记住,您可以自己编写事件访问器。例如:
public static event EventHandler TestEvent
{
add
{
lock (lockObj)
{
EventHandler oldDel;
if (EventMapping.TryGetValue(0, out oldDel))
EventMapping[0] = oldDel + value;
else
EventMapping.Add(0, value);
}
}
remove
{
lock (lockObj)
{
EventHandler oldDel;
if (EventMapping.TryGetValue(0, out oldDel))
EventMapping[0] = oldDel - value;
}
}
}
private static readonly object lockObj = new object();
private static Dictionary<int, EventHandler> EventMapping = new Dictionary<int, EventHandler>();
有了这个代码,当你去的时候:
TestEvent += GTKWavePipeClient_TestEvent;
您的 add
访问器被调用时 "implicit" 参数 EventHandler value
设置为 GTKWavePipeClient_TestEvent
。
委托是不可变的。您在调用 += 附加事件时将新对象分配给 TestEvent 。因此,在您的非工作场景中,字典中的对象与具有附加事件的对象不同。