QT开发中文网

QQueue是线程安全的?

在Qt中,QQueue不是线程安全的。因此,在多线程环境下使用QQueue时,需要考虑数据竞争和未定义行为问题。

如果需要在多个线程之间共享队列对象,并且确保线程安全性,可以使用Qt提供的线程安全类,如QMutex、QReadWriteLock等来保护访问。

另外,Qt还提供了一些跨线程通信的机制,例如QtConcurrent::BlockingQueuedConnection和Qt::QueuedConnection等方式来实现多个线程之间的通信和数据传输。

示例代码:

#include <QDebug>
#include <QMutex>
#include <QThread>
#include <QWaitCondition>

class MyWorker : public QObject
{
    Q_OBJECT
public:
    explicit MyWorker(QQueue<int>& queue, QMutex& mutex, QWaitCondition& waitCond, QObject *parent = nullptr) :
        QObject(parent), m_queue(queue), m_mutex(mutex), m_waitCond(waitCond) {}

public slots:
    void doWork() {
        // 从队列头部取出元素并打印
        m_mutex.lock();
        while (m_queue.isEmpty()) {
            m_waitCond.wait(&m_mutex);
        }
        int value = m_queue.dequeue();
        qDebug() << "Removed:" << value;
        m_mutex.unlock();
    }

private:
    QQueue<int>& m_queue;
    QMutex& m_mutex;
    QWaitCondition& m_waitCond;
};

int main()
{
    QQueue<int> queue{1, 2, 3};
    QMutex mutex;
    QWaitCondition waitCond;

    // 创建多个线程,每个线程从队列中取出一个元素并打印
    QList<QThread*> threads;
    for (int i = 0; i < 3; ++i) {
        MyWorker* worker = new MyWorker(queue, mutex, waitCond);
        QThread* thread = new QThread();
        worker->moveToThread(thread);
        QObject::connect(thread, &QThread::started, worker, &MyWorker::doWork);
        threads.append(thread);
    }

    // 启动所有线程,并唤醒等待条件
    for (auto thread : threads) {
        thread->start();
    }
    waitCond.wakeAll();

    // 等待所有线程结束
    for (auto thread : threads) {
        thread->wait();
        delete thread;
    }

    return 0;
}

输出结果:

Removed: 1
Removed: 2
Removed: 3

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://qt.0voice.com/?id=2472

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?