传递参数为自定义参数时
Qt的信号和槽可以传递int、double等c++常用类型变量,也可以传递QVector、QMap等Qt的容器类(当然也可以传递Qt定义的类型)。
传递自定义的结构体:
首先在定义结构体的同时需要使用Q_DECLARE_METATYPE
。通过这个宏定义可以将自定义的类型注册到Qt的元类型中,从而被Qt识别。
struct PersonInfo
{
QString Name;
int age;
};
Q_DECLARE_METATYPE(PersonInfo)
其次在信号端发射的信号类型应该是QVariant
,QVariant
是多种类型的联合,QVariant
类中有个SetValue(T& value)
方法,将自定义 T 类型的数据保存到QVariant对象中,可以理解为是自定义类型被封装成了QVariant的形式,这样,我们自定义的T类型的对象就能够通过所有参数和返回值为QVarian类型传递。
signals:
void PersonInfoSIG(QVariant info);
在发射信号之前,将自定义的结构体用QVariant包裹一下,就可以发射了。
QVariant DataInfo;
DataInfo.setValue(info);
emit PersonInfoSIG(DataInfo);
在槽函数这边,信号类型也定义为QVariant
,接收后用该结构体将数据取出来就完成了自定义结构体信号的一次传递
PersonInfo ReInfo=info.value<PersonInfo>();
扩展
信号和槽机制增强了对象间通信的灵活性,然而这也损失了一些性能。与回调函数相比较,信号和槽机制有些慢。通常,通过传递一个信号来调用槽函数将会比直接调用非虚函数慢10倍。
原因主要有:
● 需要定位接收信号的对象;
● 安全地遍历所有的关联(比如,一个信号关联到多个槽的情况);
● 编组(marshal)/解组(unmarshal)传递的参数;
● 多线程的时候,信号可能需要排队等待。
然而,与创建堆对象的new操作以及删除堆对象的delete操作相比较,信号和槽的代价只是它们很少的一部分。信号和槽机制导致的这点性能损耗,对实时应用程序是可以忽略的。与信号和槽提供的灵活性和简便性相比,这点性能的损失也是值得的。
/***************************************
多线程信号槽传递自定义参数
需求:想要使用信号传递double数组
定义信号:
void signal_double(QList);
编译&运行:
Object::connection: Cannot queue arguments of type ‘QList’
(Make sure ‘QList’ is registered using qRegisterMetaType().))
原因:
自定义的数据类型作为信号槽参数传递的时候,需要使用 qRegisterMetaType() 函数对该参数进行注册
解决:
1、添加头文件 #include
2、注册 qRegisterMetaType<QList > (“QList”);
3、注意:在哪儿连接信号和槽,在哪儿注册。