一.主要问题
在使用python运行一个程序的时候,会出现一种情况,就是运行程序会导致窗口卡顿
比如下面的代码
import sys
import threading
from PyQt5.QtGui import *
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtMultimedia import *
from PyQt5 import QtWidgets
class mmwin(QWidget):
def __init__(self):
super().__init__()
self.sec=1
self.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+1
for 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+1
for 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))
最后发现问题解决