QT中的元对象系统(二):创建自定义的QT类型
来源:互联网 发布:mac解压缩软件破解版 编辑:程序博客网 时间:2024/05/01 19:20
我们在使用QT编程时,难免要定义自己需要的类型,但像QT自己的类型如QSzie、QString之类的,都是可以存储在QViriant中的,并且这些QT的类型是可以用在基于QObject类的类型属性中和基于信号和槽的发生机制中。
如果我们想要我们自己自定义的类型可以有QT自己类型的功能的话,我们就必须注册我们的类型到QT中,这样我们才可以在我们在信号和槽的通讯机制中使用我们的类型。
在我们想要把我们的类型注册到QT中,我们必须满足QMedaType类型的要求,这有三点是必须的要求(以后章节说的也要满足这三点要求)。
1、必须要有一个公有的构造函数。
2、必须要有一个公有的拷贝构造函数。
3、必须要有一个公有的虚构函数。
下面使用QT文档中的一个例子来说明:
第一步:我们首先可以定义一个满足上面三点要求的自定义的类.
第二步:注册我们的类型
我们的自定义的类型,在QT中的QVariant中的,因为在QVariant中并不知道怎么存储和获取我们 的类型。因此我们就必须使我们的类型成为和QString一样的通用类型,这就需要QT中的QMetaType来完成了。我们需要调用Q_DECLARE_METATYPE这个宏来完成。
Q_DECLARE_METATYPE(Message);
这 就可以使我们的Message可以存储在QVariant中了。Q_DECLARE_METATYPE可以使我们的类型使用在信号的参数中,是直接使用 在信号-槽的通讯中的,但不可以用在基于消息队列中的信号-槽的机制中的,例如我们在线程中的通讯,上面的那种定义就做不到了。这是因为,上面的那种定义 是用宏来静态定义的,在QT中的元对象系统中并不知道在运行时怎么创建和销毁我们的自定义的对象。
这是Message的实现代码:
最后看下我们的main函数。
我们在注册我们的Message类后,我们就可以使我们的Message类对象存储在我们的QVariant的对象中了。在main函数中,我们可以看到
QVariant stored; stored.setValue(message);
而从QVariant中获得我们的对象可以这样:
Message retrieved = stored.value<Message>();
pro文件:
HEADERS = message.h SOURCES = main.cpp / message.cpp
- QT中的元对象系统(二):创建自定义的QT类型
- QT中的元对象系统(二):创建自定义的QT类型
- QT中的元对象系统(二):创建自定义的QT类型 收藏
- QT中的元对象系统(二):创建自定义的QT类型
- QT中的元对象系统(二):创建自定义的QT类型
- QT中的元对象系统(二):创建自定义的QT类型
- QT 中的元对象系统(二):创建自定义的QT类型
- QT中的元对象系统
- Qt中的元对象系统
- Qt中的元对象系统
- Qt中的元对象系统
- Qt的元对象系统
- Qt的元对象系统
- Qt的元对象系统
- qt 的元对象系统
- QT中的元对象系统 简介
- Qt元对象系统
- Qt元对象系统
- 内存池(MemPool)技术详解
- 在Linux下使用文件链接而不是拷贝一个文件的好处是什么?
- 聚类
- arm-linux-gcc编译x264
- HDU 2816 I Love You Too
- QT中的元对象系统(二):创建自定义的QT类型
- 最快速度找到内存泄漏
- 插入排序
- sql中的case when then else end,列值的选择输出
- ChartDirector 5.0 for python 笔记【11】Icon Pie Chart 上篇
- MPEG-2的系统
- Eclipse找不到C\C++头文件解决
- QT中的元对象系统(一):QVariant的简单说明
- Memory Layout for Multiple and Virtual Inheritance