mysql 线程内存 回收_使用moveToThread线程并正确回收内存的方式

本文通过UDP示例介绍如何在Qt中利用moveToThread确保MySQL线程内存的正确回收。关键点包括:1) QUdpSocket的new和delete必须在子线程的槽函数中执行;2) 在main中声明为指针类型的Myudp对象,并将其析构与线程退出信号连接;3) 主程序析构时终止QThread。
摘要由CSDN通过智能技术生成

用udp举例子。

1、封装QUdpSocket类名为Myudp,QUdpSocket的new和delete都必须要要在子线程

new:

fabe4cc7454f49f18d88fcc110dd6625.png

delete:

9487080790c06d9b5601041a7dd716d1.png

2、在main里生成封装的对象

udp = newMyudp;//头文件里声明

QObject::connect(&udpThread,&QThread::finished,[=](){

Mymethod::record("quit udpthread",PRINT_INFO);

udp->deleteLater();

});

udp->moveToThread(&udpThread);

udpThread.start();

3、在main的析构函数里退出线程

udpThread.quit();

udpThread.wait();

总结:

按照上面的方式就能正确回收内存,关闭程序Qt也不会告诉你“程序强制结束”之类的话,为什么能达到这各效果,有下面几个核心:

1、Myudp中QUdpSocket的new和delete都要放在槽函数里执行

new必须要在槽函数能理解,因为我们知道movoToThread的特性就是:只有在目标线程里new的对象才能正常在这个线程里运行,而构造函数是在main里运行的,自然只能在槽函数里new;

而我们往往习惯把delete放在析构函数里(本人就是这样使用了好几年),虽然对程序影响不大,但是这样QUdpSocket不会由程序员回收而是被操作系统回收的,因为析构函数也是运行在主线程的,根本原因和上面一样:构造函数和析构函数都是运行在main里的。

2、在main里的Myudp对象要声明成指针类型

测试的来,原因还没深究;然后要把依附线程的退出信号和Myudp的deleter连接起来

3、在main的析构里让QThread结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值