【问题标题】:C++ calling a function pointer stored in a struct in a mapC ++调用存储在映射结构中的函数指针
【发布时间】:2018-01-05 09:53:37
【问题描述】:

我在尝试调用函数指针时收到错误 term does not evaluate to a function taking 1 arguments

函数指针存储在结构中。然后将该结构存储在映射中。 定义:

typedef void (CLIOptions::*OptionHandler)(QString);

struct OptionDefinition {
   QString name;
   QString description;
   QString type;
   OptionHandler handler;
};

typedef std::map<QString, OptionDefinition> CLIOptionMap;

我这样初始化地图:

CLIOptionMap optionMap =
{
   {
      QString("set-tcp-host"),
      {
         QString("set-tcph"),
         QString("Set the TCP server host address"),
         QString("string"),
         &CLIOptions::setTcpHost
      }
   },
  // etc...
}

当我尝试遍历地图并调用处理程序时出现问题:

for (it = optionMap.begin(); it != optionMap.end(); ++it) {
    QString value = /*snip...*/

    (it->second.handler)(value)
}

我的问题是什么?

【问题讨论】:

  • 您编写的代码行如何知道调用该成员函数的 CLIOptions 实例?
  • @EdgarRokyan :不。it-&gt;second.handler 是 pmf。然后你需要像this-&gt;*(it-&gt;second.handler)(value) 这样的东西。这已经够复杂了,为了便于阅读,我推荐一个中间变量。

标签: c++ pointers struct function-pointers stdmap


【解决方案1】:

你的问题是你没有函数指针,你有一个指向成员函数的指针,它们是非常不同的野兽。指向成员函数的指针甚至不是一般的指针(它必须能够处理指向第二个虚拟基类中的虚拟函数的指针!)

假设你有一个 pmf,你需要一个对象来调用 pmfon。所以像:

for (it = optionMap.begin(); it != optionMap.end(); ++it) {
    QString value = /*snip...*/
    const auto pmf = it->second.handler;
    (mOptionHandler.*pmf)(value);
}

其实,如果你打算使用C++11auto,你也可以使用foreach循环:

for (const auto& option : optionMap) {
   const auto pmf = option.handler;
   (mOptionHandler.*pmf)(option.value);
}

【讨论】:

  • 谢谢。所以我有一个名为mOptionHandler 的可用“CLIOptions”实例,所以我设置了类似(mOptionHandler.pmf) 的调用,但这给出了CLIOptions has no member pmf
  • 哦,我只是错过了我认为的取消引用:mOptionHandler.*pmf
  • 我已将示例更改为使用您的姓名。是的 - .* 运算符与 . 运算符完全不同!
猜你喜欢
  • 2022-10-01
  • 2015-12-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-01-11
  • 2017-11-24
  • 2020-11-03
相关资源
最近更新 更多