我有两节课; A类通知B类一些事件。
typedef void (*callbackb) (B *, int param1);
class A
{
callbackb callme;
B *parent;
};
class B
{
A ai;
void set_cb() { ai.callme = cb_handler; }
static void cb_handler (B *obj, int param1) { obj->real_handler(param1); }
void real_handler(int param1);
};
有两个等效的声明,callbackb和cb_handler,但其中一个是函数指针,另一个是函数。是否可以更改其中一个或两个,以便两者都链接到单个原型声明?
答案 0 :(得分:1)
你不能像你想要的那样定义 cb_handler
。但你当然可以根据相同的原型声明它们并让编译器检查它。它也阻止你隐藏指针语义,这是一件好事。方法如下:
将回调定义为函数类型:
typedef void callbackb(B *, int param1);
根据CB类型声明指针和静态成员:
class A
{
callbackb *callme; // The pointer is explicit
B *parent;
};
// Later
class B
{
// ...
static inline callbackb cb_handler; // This is a function declaration
};
// And this is the inline definition, you can put it in a header
inline void B::cb_handler (B *obj, int param1) { obj->real_handler(param1); }
所以现在cb_handler
和callme
以相同的类型声明。您需要在定义 cb_handler
时指定完整的原型,但它仍然可以是标题中的inline
类外定义。
编译器会检查cb_handler
的定义是否与声明匹配,因此如果cb_handler
与callbackb
不同,您会收到通知。