我有一个服务器类,它处理QJsonObject
数据并根据数据中设置的键进行处理。
目前,我使用一个大的if-then-else语句来决定像这样做什么:
const QString action = jsonObject.value(KEY_ACTION).toString();
if (action == SOME_ACTION) {
// do something
} else if (action == SOME_OTHER_ACTION) {
// do something else
}
等等。现在,与此同时,我有很多操作,对于每个操作,我的服务器都必须检查所有情况,直到找到正确的情况。因此,我想知道是否有更好的方法来做到这一点。
我想过在不同的函数中进行数据处理,并有一个QHash
,其中包含指向每个操作的相应函数的相应函数指针,如下所示:
在构造函数中:
const QHash<QString, void(Server::*)(const QJsonObject &)> processFunctionsMap {
{ SOME_ACTION, &Server::processSomeAction },
{ SOME_OTHER_ACTION, &Server::processSomeOtherAction }
}
以及相应的功能:
void Server::processSomeAction(const QJsonObject &data)
{
...
}
然后调用匹配函数:
if (! processFunctionsMap.contains(action)) {
// Catch this case
}
(this->*processFunctionsMap.value(action))(jsonObject);
这似乎有效,但我不是C++专业人士,所以我的问题是这是否是正确的方法。
您的方法是合理的,但您已将无匹配场景从执行else
块(可能根本不执行任何操作(更改为即时未定义行为。
您需要将哈希查找与调用分开,以便可以在两者之间插入检查以成功查找。 对于C++标准集合(std::map
是一棵红黑树,std::unordered_map
是一个哈希表(,这将是对返回迭代器的find(key)
的调用......您将它与map.end()
进行比较,并确保如果它们相等,则不要取消引用。QHash
,或任何其他非标准哈希表,肯定会提供类似的东西。
- 了解 QHash 在找不到密钥时会执行的操作