在我的Qt应用程序中,我希望能够在用户按下快捷方式时将选项卡添加到非静态QTabWidget
中。通常我会这样实现:
File.addAction("Settings", openSettings, Qt::ALT + Qt::Key_S);
其中File
是QTabWidget
,而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
类型的静态对象,那么我将解决这个问题,显然不是这种情况。鉴于我目前的思考过程有误,我该怎么做?
答案 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
。您可以用类的名称代替。)