重点:QObject 的拷贝构造和赋值操作——私有

QObject 中没有提供一个拷贝构造函数和赋值操作符给外界使用,其实拷贝构造和赋值的操作都是已经声明了的,但是它们被使用了Q_DISABLE_COPY () 宏放在了private区域。因此所有继承自QObject的类都使用这个宏声明了他们的拷贝构造函数和赋值操作符为私有。

为什么要这样做?

 

我 们都知道Qt对标准C++增加了一些功能:signals, slots, object properties, events, event filters, string translation, timers,object trees, guarded pointers, dynamic cast.

新加入的这些功能就要求我们把每一个QObject的对象看做是唯一(identities)的。唯一的意思就是不能通过拷贝或者赋值操作

制作出一个一模一样的复制体。

试 想如果我们有一个QPushButton对象btnSubmit,如果我们可以复制出一个和btnSubmint完全一样的button对象,那么新的 button对象的名字应该是什么?如果也叫btnSubmit,当我们给其中的btnSubmit接收事件或发出信号时,系统如何区分把事件由哪个 button对象接收,或者哪个对象发送了信号?

 

我们知道在各种容器中能以value方式存放的类型,必须有默认的构造函数,拷贝构造函数和赋值操作。由于QObject及所有继承自它的子类都没 有提供拷贝构造和赋值操作,当我们使用QList<QObject>时,编译器就会报错。如果我们要在容器中存储这中类型的对象,我们就要使 用它们的指针。如QList<QObject *>

 

转自:http://wan-2004.iteye.com/blog/1134186

#include "datapool.h" #include<QDebug> // 静态成员初始化 QMutex datapool::m_instanceMutex; datapool* datapool::m_instance = nullptr; datapool *datapool::instance() { //双重检查锁定模式 if(!m_instance) { QMutexLocker locker(&m_instanceMutex); if(!m_instance) { m_instance=new datapool(); } } return m_instance; } datapool::datapool(QObject *parent) : QObject{parent} { } void datapool::addData(const QByteArray &data) { QMutexLocker locker(&m_mutex); m_dataQueue.enqueue(data); // qInfo()<<data; //这一步也是正常的 emit dataReceived(); // 通知订阅者 } QByteArray datapool::takeData() { QMutexLocker locker(&m_mutex); return m_dataQueue.dequeue(); } bool datapool::isEmpty() const { QMutexLocker locker(&m_mutex); return m_dataQueue.isEmpty(); } #ifndef DATAPOOL_H #define DATAPOOL_H #include <QObject> #include <QQueue> #include <QMutex> #include <QMutexLocker> class datapool : public QObject { Q_OBJECT public: //单例访问接口(线程安全版本) static datapool* instance(); //删除拷贝构造赋值运算符防止多实例问题 datapool(const datapool&)=delete; datapool& operator=(const datapool&) = delete; void addData(const QByteArray &data); QByteArray takeData(); bool isEmpty() const; signals: void dataReceived(); // 数据到达信号 private: explicit datapool(QObject *parent = nullptr);//构造函数私有 static QMutex m_instanceMutex; // 单例实例互斥锁 static datapool* m_instance; // 单例实例指针 QQueue<QByteArray> m_dataQueue; mutable QMutex m_mutex; }; #endif // DATAPOOL_H 在取数据时候出现卡死异常takedata
最新发布
03-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值