无效使用非静态成员函数

时间:2019-02-06 03:03:00

标签: c++ qt qt5

在我的Qt应用程序中,我希望能够在用户按下快捷方式时将选项卡添加到非静态QTabWidget中。通常我会这样实现:

File.addAction("Settings", openSettings, Qt::ALT + Qt::Key_S);

其中FileQTabWidget,而openSettings是静态方法。唯一的问题是它仅适用于静态方法,而那个问题是我无法在静态方法中访问非静态变量。因此,我认为由于Qt要求该函数为静态函数,因此可以实例化静态std::function<>对象,如下所示:

static std::function<void(void)> openSettings_ = []() { openSettings; };

并这样称呼

File.addAction("Settings", openSettings_, Qt::ALT + Qt::Key_S);

与此相关的问题是它会生成错误:

Error: invalid use of non-static member function 'void window::openSettings()'

我这样做的原因是我熟悉C,并假设Qt调用函子与几乎是对象的函数指针几乎相同。因此,我假设如果要实例化一个指向/执行非静态功能的std::function类型的静态对象,那么我将解决这个问题,显然不是这种情况。鉴于我目前的思考过程有误,我该怎么做?

1 个答案:

答案 0 :(得分:2)

首先,引发立即错误,因为您实际上并未调用该函数。您必须调用它:openSettings();

但是,这不起作用。 openSettings是非静态成员函数。所有这些普通成员函数都使用一个隐式this指针指向在其上调用它们的对象。这意味着,如果没有在其上调用对象的对象,则无法直接调用openSettings函数。但是this不会被您编写的lambda捕获,这意味着不存在此类对象。

可以通过在lambda中捕获this,例如auto openSettings_ = [this]() { this->openSettings(); }来解决此问题;

但是,另一方面,此功能就像插槽一样。您应该使用标准的信号/插槽语法将感兴趣的信号直接附加到信号上,而不是编写单独的函子。就是这样。

File.addAction("Settings", this, &(decltype(*this))::openSettings, Qt::ALT + Qt::Key_S);

(请注意,由于我不确定decltype是什么类型,因此我使用的是*this。您可以用类的名称代替。)