Qt 线程中断(终止,退出)

本文探讨了如何在C++中优雅地中断线程。通过使用`requestInterruption()`设置中断标志,和`isInterruptionRequested()`检查标志来实现线程的中断。在子线程执行任务时,会定期检查中断标志,一旦发现请求中断,它会结束当前任务并退出,但不会立即停止。这种方法确保了任务的原子性和系统的稳定。同时,文章提到了可能的锁机制实现,以减小锁的粒度。

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

前言
场景: 有的时候我们开线程做耗时的任务, 但很久了也没有完成, 我可能会有会暂停线程(或者中止)

    Worker = make_shared<WorkerRandom>()
    Thread.start();
    Worker->moveToThread(&Thread);
    connect(this, &RandomNum::OperateRun, Worker.get(), &WorkerRandom::StatrRun);
    void threadquit()
    {
    	Thread.requestInterruption();
    }
    void StatrRun
    {
		for( auto &task: TaskList)
		{
			if(QThread::currentThread()->isInterruptionRequested())
            {
                return;
            }
           //Task do smoething
		}
	}

其实用到的就是这两个函数

1requestInterruption()      设置中断标志
想中断的时候, “主线成”调用她
2isInterruptionRequested()  检查中断标志
子线程每次做任务的时候先调用她做判断,检查到有中断, 则退出线程。

注意

子线程如果是有很多任务,当要中断线程的时候, 他并不会立刻终止, 他仍会将当前正在执行的任务运行完在退出

如下操作

for( auto &task: TaskList)
{
	if(QThread::currentThread()->isInterruptionRequested())
    {
         return;
    }
   // task do smoething 
}

原理:(只是猜想)

感觉就是 利用 对一个变量进行 枷锁解锁机制


QMutex mutex;
// 主线程
mutex.lock();
Interrupt = true;
mutex.unlock();`
//次线程
//mutex.lock();
if(Interrupt)
{
    mutex.lock();   锁的颗粒度尽可能小一点
    Interrupt = false
    /mutex.unlock();`
	return ;
}
//mutex.unlock();`

// 当然用 QMutexLocker 代替 QMutex 更好
``



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值