龙空技术网

python使用线程解决窗口卡顿问题

超维Ai 133

前言:

此时大家对“qtimerpython”可能比较关怀,同学们都想要分析一些“qtimerpython”的相关文章。那么小编同时在网摘上收集了一些关于“qtimerpython””的相关知识,希望朋友们能喜欢,兄弟们快快来了解一下吧!

一.主要问题

在使用python运行一个程序的时候,会出现一种情况,就是运行程序会导致窗口卡顿

比如下面的代码

import sysimport threadingfrom PyQt5.QtGui import *from PyQt5.QtCore import *from PyQt5.QtWidgets import *from PyQt5.QtMultimedia import *from PyQt5 import QtWidgetsclass mmwin(QWidget):def __init__(self):super().__init__()self.sec=1self.icdnumber=QtWidgets.QLCDNumber(5,self)self.icdnumber.setGeometry(0,0,400,200)self.icdnumber.display("0")self.icdnumber.setStyleSheet("color:red")self.timer = QTimer(self)self.timer.start(100)#每隔0.1秒会执行self.musictime 这个函数有100000000次for循环 所以会导致函数没有完成再次执行 陷入死循环self.timer.timeout.connect(self.musictime)self.setGeometry(200, 200, 800, 400)self.setWindowTitle('cat music')self.show()def musictime(self):self.sec=self.sec+1for i in range(100000000):print()self.icdnumber.display(self.sec)if __name__ =='__main__':app=QApplication(sys.argv)ex=mmwin()sys.exit(app.exec_())

然后运行截图是这样的,会出现没有响应的情况

二.问题分析

之所以会出现这种情况是因为有原因,在这里答主定义三个程序段,a程序段,b程序段,c程序段,它们的执行顺序是a->b->c如果b没有执行完成就去执行c那么就会发生卡顿的情况,

因为b是被调用的,比如定义下面的代码段:

self.timer = QTimer(self)self.timer.start(100)#每隔0.1秒会执行self.musictime 这个函数有100000000次for循环 所以会导致函数没有完成再次执行 陷入死循环self.timer.timeout.connect(self.musictime)

这个代码会每隔0.1秒会执行self.musictime这个函数

def musictime(self):self.sec=self.sec+1for i in range(100000000):print()self.icdnumber.display(self.sec)

但是你会发现这个函数有一亿次for循环,显然每隔0.1秒执行这个函数但是这个函数并没有结束,类似你需要花费10秒钟打篮球,但是打篮球至少需要一个小时

三.问题解决

为了解决这个问题,引入线程技术,我们定义一个线程

def thread(self,func,*args):#fun是一个函数 args是一组参数对象'''将函数打包进线程'''t=threading.Thread(target=func,args=args)#target接受函数对象 arg接受参数 线程会把这个参数传递给func这个函数t.setDaemon(True)#守护t.start()#启动线程

然后我们不再执行函数,而是使用线程打包函数,执行这个线程

self.timer.timeout.connect(lambda :self.thread(self.musictime))

最后发现问题解决

标签: #qtimerpython