博客
关于我
Qt安全使用线程
阅读量:240 次
发布时间:2019-03-01

本文共 653 字,大约阅读时间需要 2 分钟。

       使用背景:项目中需要开线程去播放声音、视频,简单的线程可以实现,Qt中简单的线程就是继承QThread类,然后重新run()方法即可,但是new出来的对象要时刻记得释放,不然就会有崩溃问题。于是想办法使用更为安全的线程,让系统替自己去管理new的对象,就是使用QRunnable类结合线程池实现。

       初始方法:

.h

class PlayThread : public QThread{public:    void run();};

.cpp

void PlayThread::run(){    my_exec("aplay test.wav");    this->deleteLater();}

      更改后得方法:

.h

class playThread : public QRunnable{public:    playThread(){}    explicit playThread(QString music){this->music = music;}    void run();private:    QString music {"test.wav"};}

.cpp

void playThread::run(){    my_exec(("aplay "+this->music));}

      使用方法和之前一样,包含头文件,在使用的类,私有成员中声明一个QThreadPool *playpool;然后再cpp中调用:playpool->start(new playThread);即可。

 

转载地址:http://vret.baihongyu.com/

你可能感兴趣的文章
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>