我知道这个问题已经被问过很多次了,因此很难深入挖掘并找到一个简单的例子来说明什么是有效的。
我有这个,它很简单,适用于 MyClass
…
#include <iostream>
using std::cout;
using std::endl;
class MyClass
{
public:
MyClass();
static void Callback(MyClass* instance, int x);
private:
int private_x;
};
class EventHandler
{
public:
void addHandler(MyClass* owner)
{
cout << "Handler added..." << endl;
//Let's pretend an event just occured
owner->Callback(owner,1);
}
};
EventHandler* handler;
MyClass::MyClass()
{
private_x = 5;
handler->addHandler(this);
}
void MyClass::Callback(MyClass* instance, int x)
{
cout << x + instance->private_x << endl;
}
int main(int argc, char** argv)
{
handler = new EventHandler();
MyClass* myClass = new MyClass();
}
class YourClass
{
public:
YourClass();
static void Callback(YourClass* instance, int x);
};
如何重写,所以 EventHandler::addHandler()
将同时适用于 MyClass
和 YourClass
。很抱歉,但这只是我大脑的工作方式,我需要先看一个简单的例子来说明什么是有效的,然后才能理解它为什么/如何工作。如果您有最喜欢的方式来完成这项工作,现在是展示它的时候了,请标记该代码并将其发回。
[编辑]
它已被回答,但在我打勾之前答案已被删除。就我而言,答案是模板化函数。将 addHandler 更改为此…
class EventHandler
{
public:
template<typename T>
void addHandler(T* owner)
{
cout << "Handler added..." << endl;
//Let's pretend an event just occured
owner->Callback(owner,1);
}
};
原文由 BentFX 发布,翻译遵循 CC BY-SA 4.0 许可协议
您可以使用新的 C++11 标准中的功能,而不是使用静态方法并传递指向类实例的指针:
std::function
和std::bind
:addHandler
方法现在接受一个std::function
参数,并且这个“函数对象”没有返回值并且接受一个整数作为参数。要将其绑定到特定函数,请使用
std::bind
:添加处理程序时,您需要使用
std::bind
,因为您需要明确指定其他隐含的this
指针作为参数。如果您有独立功能,则不必使用std::bind
:让事件处理程序使用
std::function
对象,也可以使用新的 C++11 lambda 函数: