其他成员函数的通用"成员函数"包装器?

Generic 'member function' wrapper for other member function(s)?

本文关键字:函数 成员 包装 其他      更新时间:2023-10-16

我有一个接口,我必须在其中传递成员函数指针,这些指针被静态转换为基本指针,并在我们背后存储为空指针和调用类型(mfc 消息表(。

我创建了一个包装器来执行一些异常处理(非常简单的尝试/捕获以捕获 std::runtime_error(,因为这很乏味且在每个用户回调中都容易出错。

到目前为止,以下包装器实际上运行良好(这个想法是直接获取成员函数指针作为值模板参数- 本质上为每个回调函数提供一个成员函数包装器。

class MyClass : public CWnd/*example*/{
public:
template<void (MyClass::*f)(CCmdUI*)>
void Dispatch(CCmdUI* pCmdUI) {
try {
(this->*f)(pCmdUI);
}
catch (std::runtime_error& e) {
//handle error
}
}
};

但是为了避免每种类型的调用都有显式重载 - 是否可以参数化参数列表?

插图(请注意,这不起作用(:

template<void (MyClass::*f)(Args...)>
void Dispatch(Args... args) {

由于您使用的是 C++17,因此您可以在模板参数上使用auto

template<auto f, typename... Args>
void Dispatch(Args... args) {
//...

并通过将指向成员函数的指针作为模板参数 #1 来正常调用它们。活生生的例子。

如果需要检查f是否是指向该类的成员函数的指针,可以在调用(this->*f)(args...)之前使用一些static_assert语句。

还有一件小事:如果您使用的是右值语义,那么接收Args&&并使用std::forward也是一个好主意。