【第22期】观点:IT 行业加班,到底有没有价值?

Qt 多线程(QThreadPool)

原创 2016年06月02日 00:21:51

开发环境 Qt5.5.1、Qt Creator 3.5.1 

#include <QCoreApplication>
#include <QObject>
#include <QDebug>
#include <QThread>
#include <QThreadPool>
#include <QPointer>

class MyRunnable;
//事件类
class MyEvent: public QEvent {
public:
    MyRunnable *m_runnable;
    QString m_message;
    MyEvent(MyRunnable *r, QString message): QEvent(eventType()), m_runnable(r), m_message(message) { }
    static QEvent::Type eventType(){
        if(s_eventType == QEvent::None) {
            //注册一个自定义类型1000-65535
            s_eventType = (QEvent::Type)registerEventType();
            //qDebug()<<"registerEventType "<<(int)s_eventType;
        }
        return s_eventType;
    }
private:
    static QEvent::Type s_eventType;
};
QEvent::Type MyEvent::s_eventType = QEvent::None;

//线程的耗时操作
class MyRunnable :public QRunnable{
public:
    MyRunnable(QObject* observer): m_observer(observer){
    }
    //Override
    void run();
private:
    //QPointer是为QObject对象提供保护指针的模板类
    //一个保护指针 QPointer,行为类似正常的C++指针,只不过其在引用对象删除之后会自动设置为0. T必须是QObject的子类
    //保护指针在你要保存别人创建的QObject对象,且有可能其已经被删除而你仍然持有其引用的时候非常有用。
    //Qt也提供QSharedPointer,一个基于引用计数的共享指针对象实现,其能使用单个指针用于维护一个引用集合
    //就是说,如果指代的对象被删除,则后面对该对象的所有操作不会执行,因此也不会抛异常
    QPointer<QObject> m_observer;
};
//Override
void MyRunnable::run() {
    QString message;
    message.append(QString::number((int)QThread::currentThreadId())+" start\r\n");
    message.append(QThread::currentThread()->objectName()+"\r\n");
    QThread::sleep(1);
    message.append(QString::number((int)QThread::currentThreadId())+" end\r\n");
    QCoreApplication::postEvent(m_observer, new MyEvent(this, message));
}

//主程序中的消息处理程序
class MyProcesser: public QObject {
public:
    MyProcesser() {
    }
    //Override
    bool event(QEvent *);
    void process();
    void abort();
private:
    QList<MyRunnable*> m_runnableList;

};
bool MyProcesser::event(QEvent *e) {
    if(e->type() == MyEvent::eventType()) {
        qDebug()<<"processer get event, type is "<<(int)e->type();
        qDebug()<<((MyEvent*)e)->m_message;
        m_runnableList.removeOne(((MyEvent*)e)->m_runnable);
    }
}
void MyProcesser::process() {
    MyRunnable* runnable = new MyRunnable(this);
    m_runnableList.append(runnable);
    //是否线程池替你删除
    //If auto-deletion is enabled, QThreadPool will automatically delete this runnable after calling run();
    //otherwise, ownership remains with the application programmer.
    runnable->setAutoDelete(false);
    QThreadPool::globalInstance()->start(runnable);
}
void MyProcesser::abort() {
    int size = m_runnableList.size();
    MyRunnable* r;
    for(int i=0;i<size;i++) {
        r = m_runnableList.at(i);
        m_runnableList.removeAt(i);
    }
}


int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    qDebug()<<"main thread "<<QThread::currentThreadId()<<" start";
    qDebug()<<"main thread "<<QThread::currentThread()->objectName();
    MyProcesser processer;
    processer.process();
    processer.process();
    return a.exec();
}



            
版权声明:转载请注明出处——http://blog.csdn.net/chy555chy/article 举报

相关文章推荐

QT线程池实验研究与分析(QThread与和QThreadPool + QRunnable使用上的区别)

第一部分:QT线程池的构建与使用     网上关于QT线程池QThreadPool的文章很多,而且大都千篇一律,基本上都是参考QT的帮助文档介绍QT全局线程池的用法。这样就往往会使人产生误解,QT是不...

Qt 线程基础(QThread、QtConcurrent、QThreadPool等)

Qt 线程基础(QThread、QtConcurrent、QThreadPool等)   2012-06-25 11:42:56|  分类: Qt|字号 订阅 使用...

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

QT 5.10+MinGW4.8 程序的静态编译

2篇文章参考 ,瞎搞1天,N次重新搭建,终于成功了,大家别走弯路了,推荐2篇文章: Qt5.1.0 MinGW4.8 release静态版编译结果分享       http://w...

呵呵 我的第一个QT界面程序~

运行时显示:

用QT获取NGA大脚用户的魔兽角色信息

魔兽大脚角色绑定+魔兽大脚和NGA账号+NGA手机APP

QT网页信息扫描~

抓个小站信息 只需几秒~

QRunnable与多线程

前面的博文中,我们讲过QtConcurrent模块,该模块是Qt中实现并发编程的高级API接口,而QRunnable结合QThreadPoll和QThread都是Qt中与并发编程相关的低级接口。今天我...

QT保持的最佳线程并发数(信号与槽+progressBar读数)

利用线程结束信号 连接槽 产生新的线程 产生传递如果数组可利用UI中的进度条值, 并发最佳数量 ,完成1个,触发槽开一个新线程 直到结束; for(int i=0; iidealThr...

验证码识别产生的神奇网站

验证码识别与反识别技术,矛和盾的关系,但是验证码终归还是要让人看清楚其内容, 完全靠软件识别分析是太难,0和o ,O和0 ,9和g,I和1,I和l,l和1,在不同字体下和变形情况下匹配, 用软件识别出...

QT5.1+MinGW+免安装MYSQL-5.1.6环境搭建

三部配置: 1.首先QT5.1验证数据库驱动,代码如下: QApplication a(argc, argv); MainWindow w; w.show(); ...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)