托管事件
有关新语法中的编码事件的信息,请参阅event(C++ 组件扩展)。
托管事件是数据成员或方法。当与事件一起使用时,委托的返回类型必须符合公共语言规范。事件处理程序的返回类型必须与委托的返回类型匹配。有关委托的详细信息,请参阅 __delegate。如果托管事件是数据成员,则其类型必须是指向委托的指针。
在 .NET Framework 中,您可以将数据成员视为方法本身(即,其对应委托的 Invoke 方法)。您必须预定义用于声明托管事件数据成员的委托类型。相反,如果尚未定义对应的托管委托,则托管事件方法将隐式定义它。例如,您可以将事件值(如 OnClick)声明为下面所示的事件:
// Examples of managed events:
__event ClickEventHandler* OnClick; // data member as event
__event void OnClick(String* s); // method as event
隐式声明托管事件时,您可以指定添加或移除添加或移除事件处理程序时将调用的 add 和 remove 访问器。您还可以定义从类外部调用(引发)事件的方法。
示例:本机事件
// EventHandling_Native_Event.cpp
// compile with: /c
[event_source(native)]
class CSource {
public:
__event void MyEvent(int nValue);
};
示例:COM 事件
// EventHandling_COM_Event.cpp
// compile with: /c
#define _ATL_ATTRIBUTES 1
#include <atlbase.h>
#include <atlcom.h>
[ module(dll, name="EventSource", uuid="6E46B59E-89C3-4c15-A6D8-B8A1CEC98830") ];
[ dual, uuid("00000000-0000-0000-0000-000000000002") ]
__interface IEventSource {
[id(1)] HRESULT MyEvent();
};
[ coclass, uuid("00000000-0000-0000-0000-000000000003"), event_source(com) ]
class CSource : public IEventSource {
public:
__event __interface IEventSource;
HRESULT FireEvent() {
__raise MyEvent();
return S_OK;
}
};
示例:托管事件
// EventHandling_Managed_Event.cpp
// compile with: /clr:oldSyntax /c
using namespace System;
[event_source(managed)]
public __gc class CPSource {
public:
__event void MyEvent(Int16 nValue);
};
将特性应用于事件时,您可以指定特性应用于生成的方法还是生成的委托的 Invoke 方法。默认值 (event:) 用于将特性应用于事件。
// EventHandling_Managed_Event_2.cpp
// compile with: /clr:oldSyntax /c
using namespace System;
[attribute(All, AllowMultiple=true)]
public __gc class Attr {};
public __delegate void D();
public __gc class X {
public:
[method:Attr] __event D* E;
[returnvalue:Attr] __event void noE();
};










