基本上,标题......如果没有QThread(或者只是评论)我得到以下结果:
LOG> Log working!
LOG> PRODUCER: sent resource address: 29980624
PRODUCER: sent resource address: 29980624
CONSUMER: received resource address: 29980624
29980624,或任何相关的记忆位置。
但是,当没有评论时
LOG> Log working!
mainwindow.h
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = 0);
~MainWindow();
public slots:
void slot_log(QString str);
signals:
void signal_log(QString str);
private:
void createConsumer( void );
void deleteConsumer( void );
void createProducer( void );
void deleteProducer( void );
void createConnections( void );
SingleConsumer *consumer;
QThread *thread_consumer;
SingleProducer *producer;
QThread *thread_producer;
};
mainwindow.cpp
#include "mainwindow.h"
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent)
{
createConsumer();
createProducer();
createConnections();
QTimer::singleShot(1000, producer, SLOT(slot_publishResourceAddress()) );
}
void MainWindow::slot_log(QString str)
{
qWarning( QString("LOG> %1").arg(str).toUtf8() );
}
void MainWindow::createConnections( void )
{
connect(this, SIGNAL(signal_log(QString)), this, SLOT(slot_log(QString)));
emit signal_log(QString("Log working!"));
connect(producer, SIGNAL(signal_resourceAddress(uint_fast8_t*)), consumer, SLOT(slot_resource(uint_fast8_t*)));
}
void MainWindow::createProducer( void )
{
producer = new SingleProducer();
thread_producer = new QThread();
producer->moveToThread(thread_producer); // THIS LINE DESERVES ATTENTION
connect(producer, SIGNAL(signal_log(QString)), this, SLOT(slot_log(QString)));
}
singleproducer.h
#ifndef SINGLEPRODUCER_H
#define SINGLEPRODUCER_H
#include <QWidget>
class SingleProducer : public QObject
{
Q_OBJECT
public:
explicit SingleProducer(QObject *parent = nullptr);
signals:
void signal_resourceAddress( uint_fast8_t* addr );
void signal_log(QString str);
public slots:
void slot_publishResourceAddress( void )
{
emit signal_log( QString("PRODUCER: sent resource address: %1").arg((long int) &un_resources__) );
qWarning(QString("PRODUCER: sent resource address: %1").arg((long int) &un_resources__).toUtf8());
emit signal_resourceAddress( &un_resources__ );
}
private:
uint_fast8_t un_resources__;
};
#endif // SINGLEPRODUCER_H
编辑不允许我发布更多代码......但我认为这是最相关的部分......如果没有,请告诉我。但我在pastebin分享了它
我的错误在哪里?
在QThread
和MainWindow::createProducer
创建它们之后,你忘了实际启动MainWindow::createConsumer
s。来自documentation of the constructor of QThread
:
构造一个新的
QThread
来管理一个新线程。父母拥有QThread的所有权。在调用start()之前,线程不会开始执行。
所以你需要做的就是在创建线程后分别调用thread_producer->start()
和thread_consumer->start()
。