C++-将对象(如字符串)映射到表中成员函数的正确方法

C++ - proper way to map objects (like strings) to member functions in table

本文关键字:函数 成员 方法 对象 字符串 映射 C++-      更新时间:2023-10-16

我正在处理由第三方API定义的事件。事件由字符串标识符识别,即"EventABC"

我需要将表中的这些(字符串(事件映射到对象的成员函数。

问题

做这件事最安全、最干净的方法是什么?

在没有进一步约束的情况下,这可以通过从std::stringstd::function<void()>std::mapstd::unordered_map轻松完成。使用C++11,您可以使用lambdas来不引人注目地捕获this对象,以调用上的成员函数

class HandlerHandler
{
std::map<std::string, std::function<void()>> handlers;
void foo();
void bar();
void frobnicate();
HandlerHandler()
{
handlers["FOO"] = [this](){ foo(); };
handlers["BAR"] = [this](){ bar(); };
handlers["FROB"] = [this](){ frobnicate(); };
}
void handle(std::string h)
{
handlers[h]();
}
};

https://godbolt.org/z/nbygdF

您可能需要防止映射中不存在h的情况(目前,它将在尝试调用默认构造的函数时抛出异常(。

可以执行以下操作,将方法包装在std::function 中

#include <iostream>
#include <string>
#include <functional>
#include <map>
struct Target
{
void member1() {
std::cout << "member1n";
}
void member2() {
std::cout << "member2n";
}
};

int main()
{   
// events will be called on this object
Target myTarget; 
std::map<std::string, std::function<void(void)>> table;
table.insert({"member1", std::bind(&Target::member1, &myTarget)});
table.insert({"member2", std::bind(&Target::member2, &myTarget)});
std::string event = "member2";
table[event]();
}