前言:
此时大家对“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