Qt 线程(09-1):ThreadBasic【示例】

本文演示了如何利用QObject的线程相关性实现线程间的任务分配,并通过QThread的信号函数来控制线程的启动与停止。示例代码展示了如何创建Worker对象,并将工作负载放入独立的线程中执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ThreadBasic 示例

前言

演示使用QObject的线程相关性(线程亲和性)来使用线程 , 并使用QThread的相关信号函数。

核心函数:void QObject::moveToThread( QThread *targetThread )

更改此对象及其子对象的线程相关性。如果对象有父对象,则无法移动该对象。事件处理将在targetThread中继续。

警告:此函数不是线程安全的;当前线程必须与当前线程的关联性相同。换句话说,这个函数只能将一个对象从当前线程“推”到另一个线程,而不能将一个对象从任意线程“拉”到当前线程。但有一个例外:没有线程关联的对象可以被“拉”到当前线程。

main.cpp 代码

#include <QtCore>
class Work:public QObject{
    Q_OBJECT
public slots:
public:
    void doWork(){
        while(num > 0){
            qDebug() << QThread::currentThread()->objectName() <<  num--;
        }
    }
    static int num;  // 静态成员变量
};
int Work::num = 100;    // 声明并初始化

class Worker :public QObject{
    Q_OBJECT
public:
    Worker(){
        workThread = new QThread(this);
        connect(this,&QObject::objectNameChanged,[=]{
            workThread->setObjectName(this->objectName());
        });
    }
    ~Worker(){
        workThread->quit();
        workThread->wait();
    }
public slots:
    void putWorkInAThread(){
        Work *work = new Work;      // 对象没有父对象
        connect(workThread,&QThread::started,work,&Work::doWork);
        connect(workThread,&QThread::finished,work,&Work::deleteLater);
        work->moveToThread(workThread);
        workThread->start();
    }
private:
    QThread *workThread;    // 私有成员变量
};

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    Worker worker1,worker2,worker3;
    worker1.setObjectName("worker1");
    worker2.setObjectName("worker2");
    worker3.setObjectName("worker3");

    worker1.putWorkInAThread(); // 线程1
    worker2.putWorkInAThread(); // 线程2
    worker3.putWorkInAThread(); // 线程3
    for (int var = 0; var < 20; ++var) {
        qDebug() << QThread::currentThread() << "hello";// 主线程
    }
    a.exec();
    return 0;
}
#include "main.moc"   // moc工具
linux QT4调用websocket库环境,代码如下 {//ws websocket_tpye = websocket_no_tls; if(m_init) { m_init = false; _client_no_tls.clear_access_channels(websocketpp::log::alevel::all); _client_no_tls.clear_error_channels(websocketpp::log::elevel::all); _client_no_tls.init_asio(); _client_no_tls.start_perpetual(); client_thread = websocketpp::lib::make_shared<websocketpp::lib::thread>(&client_no_tls::run, &_client_no_tls); } websocketpp::lib::error_code ec; client_no_tls::connection_ptr con = _client_no_tls.get_connection(uri, ec); if (ec) { QDEBUG<<" could not create connection because:"<<QString::fromStdString(ec.message()); return -1; } metadata_no_tls = websocketpp::lib::make_shared<connection_metadata_no_tls>(con->get_handle(), uri); if(QString::fromStdString(password).isEmpty()) { } else { std::string val = "Basic "+base64_encode(QString::fromStdString(devnumber)+":"+QString::fromStdString(password)); con->append_header("Authorization", val); } con->set_open_handler(websocketpp::lib::bind( &connection_metadata_no_tls::on_open, metadata_no_tls, &_client_no_tls, websocketpp::lib::placeholders::_1 )); // con->set_pong_timeout(10); // con->set_pong_timeout_handler(websocketpp::lib::bind( // &connection_metadata_no_tls::on_ping, // metadata_no_tls, // &_client_no_tls, // websocketpp::lib::placeholders::_1 // )); con->set_fail_handler(websocketpp::lib::bind( &connection_metadata_no_tls::on_fail, metadata_no_tls, &_client_no_tls, websocketpp::lib::placeholders::_1 )); con->set_close_handler(websocketpp::lib::bind( &connection_metadata_no_tls::on_close, metadata_no_tls, &_client_no_tls, websocketpp::lib::placeholders::_1 )); con->set_message_handler(websocketpp::lib::bind( &connection_metadata_no_tls::on_message, metadata_no_tls, websocketpp::lib::placeholders::_1, websocketpp::lib::placeholders::_2 )); _client_no_tls.connect(con); } },如何实现定时推送ping功能
最新发布
07-05
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值