PyQt5/PySide2 Qthread第二次运行界面卡死

我写了一个界面,有五个按钮,每个按钮按下后会执行五个不同的费时的业务。
因此我将费时的业务放在了一个继承自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])

后来我还是用的继承Qrunnable 和Qobject 搞定的 

 

恭喜你,可以采纳我的回答了

https://blog.csdn.net/qq_32407233/article/details/102742791