c++ - 其他成员函数的通用 'member function' 包装器?

标签 c++ templates c++17 variadic-templates pointer-to-member

我有一个接口(interface),我必须传递成员函数指针,该指针静态转换为基指针,并在我们背后存储为空指针和调用类型 ( message tables)。

我创建了一个包装器来执行一些异常处理(非常简单的 try/catch 来捕获 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 传递给成员函数来正常调用它们。 Live Example .

如果你需要检查f是否是指向那个类的成员函数的指针,你可以在调用(this->* f)(args...).

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

关于c++ - 其他成员函数的通用 'member function' 包装器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57851452/

相关文章:

c++ - 为什么map在(switch)格外变成空的?

c++ - dynamic_cast 的正确用例是什么?

c++ - 无法获取派生类成员的值

c++ - 分段故障多项式

c++ - 模板多重定义问题

c++ - 传递给模板的 Lambda 未定义

c++ - 为什么 C++ 标准中没有 std::basic_string 类的构造函数,其参数为 std::string_view 类型

c++ - std::dynamic_pointer_cast 成功调用非初始化类

c++ - 为什么我需要 std 和字符串库才能在 C++ 中使用字符串

c++ - 继承自专业类?