0

我在 QThread 中使用 QNetworkAccessManager 时遇到麻烦。相同的功能在不使用线程的情况下也能正常工作。我目前只使用一个线程,我还需要添加更多线程。

它会触发错误消息:“Object::connect: No such slot QThread::replyFinished(QNetworkrReply*)”

头文件代码(NewThread.h)为:

class NewThread: public QThread
{
    public slots:
         void replyFinished(QNetworkReply* reply);

    protected:
         void run();

    private: 


};

The source code file(NewThread.cpp ):

void NewThread::replyFinished(QNetworkReply *net_reply)
{
    QByteArray data = net_reply->readAll();
    QString str(data);    
}


void NewThread::run()
{

QNetworkAccessManager *manager;
        manager = new QNetworkAccessManager ();
        QNetworkRequest req;
        req.setUrl(QUrl("My url"));

        QByteArray postData;

        postData.append("some data string");


        req.setHeader(QNetworkRequest::ContentTypeHeader, "application/x-www-form-urlencoded");

        manager->setCookieJar(new QNetworkCookieJar(manager));
        //Define the Request-url:
        connect (manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(replyFinish (QNetworkReply  *)));
        //Send the request:
        manager->post(req, postData);
}

void NewThread::replyFinish(QNetworkReply *reply)
{
     QString answer = QString::fromUtf8(reply->readAll());
     qDebug () << answer;
}

我正在另一个类中创建一个 NewThread 类的对象,如下所示:

NewThread thread1;
thread1.start();

我想知道为什么相同的代码在没有线程而不是线程的情况下工作。我处境艰难,任何帮助表示赞赏。

4

3 回答 3

0

在您的头文件中,您声明了replyFinished

public slots:
         void replyFinished(QNetworkReply* reply);

但是,在您的源文件中,您连接到replyFinish

connect (manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(replyFinish (QNetworkReply  *)));

QObject::connect 找不到replyFinish,因为它只是一个方法,而不是槽。请连接到正确的插槽名称。

正如其他人所说,您需要Q_OBJECT.

于 2012-10-19T09:41:15.203 回答
0

不要忘记,如果信号来自单独的线程,您需要启动捕获信号的线程的事件循环。阅读QThread的详细描述。不要忘记 Q_OBJECT 宏。

于 2012-10-18T14:11:50.860 回答
0

您需要在类声明中添加 Q_OBJECT 宏

然后你需要用Qt的“moc”工具对头文件进行预处理,并将生成的cpp文件添加到你的项目中。

一旦您将所有内容构建在一起,它应该可以正常工作

于 2012-10-18T14:17:35.790 回答