使用QFutureWatcher获取Concurrent返回的值

使用QFutureWatcher获取Concurrent返回的值

我在使用QFutureWatcher,读取QFuture实例:Concurrent返回的值。
发生下列报错:

问题描述

在这里插入图片描述

报错代码

int test_Concurrent::timeTask(int &num)
{
    
    for (int i = 0; i < 1000; i++)
    {
        num++;
        qDebug() << num;
    }
    return num;
}

void test_Concurrent::on_pushButton_clicked()
{
    
    int num = 0;
    QFutureWatcher<int>* fw = new QFutureWatcher<int>;
    connect(fw, &QFutureWatcher<int>::finished, [&] {
        qDebug()<<"return result: "<<fw->result();
        });
    fw->setFuture(future);
    if (!future.isFinished())
    {
        QApplication::processEvents(QEventLoop::AllEvents, 30);
    }

原因分析:

本人也不知道是什么原因,有知道的大佬欢迎赐教。


解决方案:

将lambda表达中的 & 换成 = 就解决问题了

在这里插入图片描述

好的,下面是一个使用Qt Concurrent的例子: 假设你有一个很长的字符串列表,你想要将其中的每个字符串转换为大写,并打印出来。使用Qt Concurrent,你可以这样实现: ```cpp #include <QtConcurrent/QtConcurrent> void printUpperCase(const QStringList& strings) { QFuture<QString> future = QtConcurrent::mapped(strings, [](const QString& str) { return str.toUpper(); }); QFutureWatcher<QString> watcher; QObject::connect(&watcher, &QFutureWatcher<QString>::finished, [&]() { const QStringList result = watcher.result(); for (const QString& str : result) { qDebug() << str; } }); watcher.setFuture(future); } int main(int argc, char* argv[]) { QCoreApplication app(argc, argv); QStringList strings = {"hello", "world", "qt", "concurrent"}; printUpperCase(strings); return app.exec(); } ``` 在这个例子中,我们定义了一个函数printUpperCase,它接受一个字符串列表作为参数。我们使用QtConcurrent::mapped函数将字符串列表中的每个字符串转换为大写,并返回一个QFuture<QString>对象。然后,我们创建了一个QFutureWatcher<QString>对象,并将其与QFuture对象关联。在QFuture执行完成后,我们会在QFutureWatcher的finished信号中获取结果,并打印出来。 在main函数中,我们创建了一个字符串列表,并调用printUpperCase函数。由于Qt Concurrent是异步执行的,因此我们可以在主线程中继续执行其他任务,而不必等待printUpperCase函数执行完成。 这仅仅是Qt Concurrent的一个简单示例,它可以帮助你处理更复杂的并发操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值