C++ Qt中的slot和method有什么区别?

C++ Qt中的slot和method有什么区别?,c++,qt,C++,Qt,slot(在slots部分声明的方法)和Qt(用Q_INVOKABLE关键字声明的方法)之间有什么区别?它们都可以使用QMetaObject::invokeMethod调用,当使用slot宏连接到插槽时,它们都被接受,但是当获取元方法类型时,可以返回QMetaMethod::Method或QMetaMethod::slot,因此,Qt似乎有一些区别?唯一的区别是该方法在类的元数据中是列为slot还是非slot。在Qt 4和Qt 5中,与插槽或可调用插槽的连接均成功: #include <Q

slot(在
slots
部分声明的方法)和Qt(用Q_INVOKABLE关键字声明的方法)之间有什么区别?它们都可以使用
QMetaObject::invokeMethod
调用,当使用
slot
宏连接到插槽时,它们都被接受,但是当获取元方法类型时,可以返回
QMetaMethod::Method
QMetaMethod::slot
,因此,Qt似乎有一些区别?

唯一的区别是该方法在类的元数据中是列为slot还是非slot。在Qt 4和Qt 5中,与插槽或可调用插槽的连接均成功:

#include <QObject>
struct Test : public QObject {
  Q_SLOT void slot() {}
  Q_INVOKABLE void invokable() {}
  Q_OBJECT
};

int main() {
  Test test;
  auto c1 = QObject::connect(&test, SIGNAL(destroyed(QObject*)), &test, SLOT(slot()));
  auto c2 = QObject::connect(&test, SIGNAL(destroyed(QObject*)), &test, SLOT(invokable()));
  Q_ASSERT(c1);
  Q_ASSERT(c2);
}
#include "main.moc"
#包括
结构测试:公共QObject{
Q_槽空槽(){}
Q_INVOKABLE void INVOKABLE(){}
Q_对象
};
int main(){
试验;
自动c1=QObject::连接并测试,信号(已销毁(QObject*),&测试,插槽(插槽());
自动c2=QObject::连接(测试和信号(已销毁(QObject*))、测试和插槽(可调用());
Q_断言(c1);
Q_断言(c2);
}
#包括“main.moc”

由用户决定如何解释插槽和可调用插槽之间的差异。例如,如果您以某种方式向用户公开插槽列表,则除非您选择这样做,否则您不会公开可调用方法列表。

我所知道的实际差异:

  • Q_INVOKABLE
    可以有一个返回值,
    signal
    不能
  • 在GUI线程上调用
    Q_INVOKABLE
    ,并阻止GUI线程<代码>信号的线程取决于创建
    QObject
    的线程,因此可以是非阻塞的

什么是“插槽列表”?你是怎么得到的?在什么情况下它会有用?@pooya13我在这里可能过于简单化了,但我发现它在将信号连接到两个插件DLL之间的插槽时很有用,并且不可能使用常规指针指向函数,因为在编译时它会“活”在尚未加载的DLL中。