我写了一个界面,有五个按钮,每个按钮按下后会执行五个不同的费时的业务。
因此我将费时的业务放在了一个继承自QObject的类中,同时创建了五个QThread。使用时再将QObject类movetoThread(这是Qt官方推荐的用法而不是重写Qthread的run函数。于是产生了一个疑问,如果这个界面将来会产生十多个不同的费时业务,就有十个Qthread吗,界面初始化的时候,创建这十多个Qthread,再创建十个业务的实例,再movetoThread就会显得代码很冗余?于是写了下面一段代码,第一次运行时,代码正常,第二次运行时,界面将会卡死,不知道是哪一步出了问题。
贴出触发线程启动和结束的代码,请指点一下迷津,谢谢!
def stop_thread(self, s, th):
"""
线程接收到实例传回的bool参数s,以及实例运行的线程th(在实例中使用Qthread,CurrentThread取得)
"""
print("接收到是否结束线程\n",th)
self.th.quit()
self.th.wait()
self.update_table2()
print("进程结束")
def th_start(self, x):
"""
使用lambda表达式将实例移动到self.th这个Qthread中,并启动线程
"""
print("接收到的开始线程\n", self.th) # 需要关闭的线程就是self.th
x.moveToThread(self.th)
print("接收线程后的线程:",self.th,QThread.currentThread())
self.th.started.connect(x.processing)
self.th.start()
def move_to_thread(self):
"""
使用lambda表达式将实例移动到self.th这个Qthread中
"""
print(QThread.thread(self.th))
print("当前线程:",QThread.currentThread())
sender = self.sender().text()
f = lambda x: self.th_start(x)
switch = {
"库存": self.storage
"路由": self.routine,
"分配": self.deliver,
"刷新": self.refresh,
"合并": self.combine
}
f(switch[sender])