Qt C++从线程发出,在插槽GUI中

Qt C ++ emit from the thread, in the slot GUI

本文关键字:插槽 GUI C++ 线程 Qt      更新时间:2023-10-16

主窗口类(GUI(中有一个插槽,它在QTextBrowser:中显示数据

void MainWindow::setLogs(QString param, QString text) {
  qDebug()<<text;
  ui->Logs->append(text);
}

有一个类在一个单独的线程中运行,进行POST搜索并将数据插入QTextBrowser:

QNetworkRequest request(apiUrl);
request.setRawHeader("User-Agent", "Mozilla/5.0 (Windows NT 6.3; WOW64; rv:38.0) Gecko/20100101 Firefox/38.0");
request.setRawHeader("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8");
request.setRawHeader("Accept-Language", "ru-RU,ru;q=0.8,en-US;q=0.5,en;q=0.3");
request.setRawHeader("Accept-Encoding", "identity");
request.setRawHeader("Connection", "keep-alive");
request.setHeader(QNetworkRequest::ContentTypeHeader,"application/x-www-form-urlencoded");
reply = manager.post(request, "data="+data);
connect(reply, &QNetworkReply::finished,this, &MakePost::getReplyFinished);
connect(reply, &QNetworkReply::readyRead, this, &MakePost::readyReadReply);
connect(reply, SIGNAL(error(QNetworkReply::NetworkError)), this, SLOT(GetError()));
void MakePost::readyReadReply()
{
  QString GetRes = QString::fromUtf8(reply->readAll());
  qDebug() << "GetRes: " + GetRes;
  emit SendLog(GetRes);
}

调用线程:

QThread *postThread = new QThread;
MakePost *sendPost = new MakePost();
sendPost->SetParam(Data, SubUrl, requestString);
sendPost->moveToThread(postThread);
sendPost->manager.moveToThread(postThread);
connect(postThread, SIGNAL(started()), sendPost, SLOT(MakePostSignal()));
postThread->start();

以及主窗口中的连接槽流:

connect(SendPost, SIGNAL(SendLog(QString)), this, SLOT(setLogs(QString)));

如果我在线程中运行时只收到结果qDebug((<lt;"GetRes:"+GetRes;以及所有。。。

请帮忙,如何在线程和GUI之间创建信号槽的连接?谢谢

网络请求已经在工作线程中异步处理:QNetworkAccessManager就是这样做的。你不需要在混合物中再添加一个线程。

对于其他CPU绑定的一次性任务,您应该通过QtConcurrent::run利用默认线程池。线程创建和销毁成本高昂,而且线程池的位置独特,可以全面了解应用程序对工作线程的需求,并最有效地管理它们的使用寿命。对于I/O绑定任务,应该使用第二个线程队列,该队列作为第一个参数传递给QtConcurrent::run