我目前正在尝试为我的引擎创建一个事件模板类。
我的事件类有一个std::vector<T>
,其中T
将被定义为指向需要事件的函数的指针。
调用事件时,它将调用具有必要参数的添加到向量中的每个函数。
问题是在尝试编译这部分代码以调用事件时。
目前是这样写的。
template <typename... Args>
void Call(Args ... args)
{
for (T f : functions)
{
f->*(args...);
}
}
请注意,我已经尝试过:
f->*((args), ...);
f->*(std::forward(args)...);
f->*(args)...;
以及许多其他类似的解决方案。
每次我尝试编译代码时,我都会遇到:
include/event.h:71:22: error: expected ‘)’ before ‘...’ token
f->*(args...);
^
include/event.h:71:26: error: parameter packs not expanded with ‘...’:
f->*(args...);
我真的不明白这里的问题。
使用参数调用函数指针和成员函数指针的语法不同。
如果是函数指针(即自由函数(,您可以这样做
f(std::forward<Args>(args)...);
对于成员函数指针,您需要一个对象(或指向对象的指针(来调用成员函数及其参数。
(pointer_to_object->*f)(std::forward<Args>(args)...);
但是,如果您可以访问 c++17,只需使用std::invoke
,它具有合适的重载来处理上述情况。
#include <utility> // std::forward
#include <functional> // std::invoke
template <typename... Args>
void Call(Args&& ... args)
// ^^^^^^^^^^^^^^ --> also forwarding reference here
{
for (T f : functions)
{
std::invoke(f, std::forward<Args>(args)...); // like this
}
}