【多线程】python界面阻塞,白屏,not responding解决的简单例子

简介: 1 # -*- coding: utf-8 -*- 2 3 import sys, time 4 from PyQt4.QtCore import * 5 from PyQt4.QtGui import * 6 x = 0 7 class Window(QWidget): 8 def __init__(self, parent = None): 9 QWidget.
 1 # -*- coding: utf-8 -*-
2
3 import sys, time
4 from PyQt4.QtCore import *
5 from PyQt4.QtGui import *
6 x = 0
7 class Window(QWidget):
8 def __init__(self, parent = None):
9 QWidget.__init__(self, parent)
10 self.thread = Worker()
11
12 # 提示信息
13 self.xLable = QLabel("Number of xTimes:")
14 # 下拉框
15 self.spinBox = QSpinBox()
16 self.spinBox.setMaximum(100)
17 self.spinBox.setValue(10)
18 self.startButton = QPushButton(self.tr("&Start"))
19 # 布局
20 layout = QGridLayout()
21 layout.addWidget(self.xLable, 0, 0)
22 layout.addWidget(self.spinBox, 0, 1)
23 layout.addWidget(self.startButton, 0, 2)
24 self.setLayout(layout)
25 # 标题
26 self.setWindowTitle(self.tr("Threading"))
27
28 # 信号
29 self.connect(self.thread, SIGNAL("finished()"), self.finishSend)
30 self.connect(self.thread, SIGNAL("update(int)"), self.updateGUIStatus)
31 self.connect(self.startButton, SIGNAL("clicked()"), self.sendAdvMail)
32
33 def sendAdvMail(self):
34 self.spinBox.setReadOnly(True)
35 self.startButton.setEnabled(False)
36 #传递值到线程中
37 self.thread.render(self.spinBox.value())
38
39 def updateGUIStatus(self, leftTime):
40 self.xLable.setText(str(leftTime))
41
42 def finishSend(self):
43 self.spinBox.setReadOnly(False)
44 self.startButton.setEnabled(True)
45
46 class Worker(QThread):
47 def __init__(self, parent = None):
48 QThread.__init__(self, parent)
49 self.exiting = False
50 self.xTimes = 0
51
52 def __del__(self):
53 self.exiting = True
54 self.wait()
55
56 def render(self, xTimes):
57 self.xTimes = xTimes
58 self.start()
59
60 def run(self):
61 # Note: This is never called directly. It is called by Qt once the
62 # thread environment has been set up.
63 n = self.xTimes
64 while not self.exiting and n > 0:
65 time.sleep(1)
66 #该信号引起界面更新
67 n -= 1
68 self.emit(SIGNAL("update(int)"), n)
69
70
71 if __name__ == "__main__":
72 app = QApplication(sys.argv)
73 window = Window()
74 window.show()
75 sys.exit(app.exec_())


编辑器加载中...

目录
相关文章
|
4月前
|
数据采集 存储 JSON
Python爬取知乎评论:多线程与异步爬虫的性能优化
Python爬取知乎评论:多线程与异步爬虫的性能优化
|
4月前
|
人工智能 安全 调度
Python并发编程之线程同步详解
并发编程在Python中至关重要,线程同步确保多线程程序正确运行。本文详解线程同步机制,包括互斥锁、信号量、事件、条件变量和队列,探讨全局解释器锁(GIL)的影响及解决线程同步问题的最佳实践,如避免全局变量、使用线程安全数据结构、精细化锁的使用等。通过示例代码帮助开发者理解并提升多线程程序的性能与可靠性。
145 0
|
17天前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
159 0
|
4月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
331 83
|
3月前
|
数据采集 消息中间件 并行计算
Python多线程与多进程性能对比:从原理到实战的深度解析
在Python编程中,多线程与多进程是提升并发性能的关键手段。本文通过实验数据、代码示例和通俗比喻,深入解析两者在不同任务类型下的性能表现,帮助开发者科学选择并发策略,优化程序效率。
201 1
|
4月前
|
数据采集 监控 调度
干货分享“用 多线程 爬取数据”:单线程 + 协程的效率反超 3 倍,这才是 Python 异步的正确打开方式
在 Python 爬虫中,多线程因 GIL 和切换开销效率低下,而协程通过用户态调度实现高并发,大幅提升爬取效率。本文详解协程原理、实战对比多线程性能,并提供最佳实践,助你掌握异步爬虫核心技术。
|
5月前
|
JSON 算法 Java
打造终端里的下载利器:Python实现可恢复式多线程下载器
在数字时代,大文件下载已成为日常需求。本文教你用Python打造专业级下载器,支持断点续传、多线程加速、速度限制等功能,显著提升终端下载体验。内容涵盖智能续传、多线程分块下载、限速控制及Rich库构建现代终端界面,助你从零构建高效下载工具。
326 1
|
4月前
|
数据采集 存储 Java
多线程Python爬虫:加速大规模学术文献采集
多线程Python爬虫:加速大规模学术文献采集
|
5月前
|
数据采集 网络协议 前端开发
Python多线程爬虫模板:从原理到实战的完整指南
多线程爬虫通过并发请求大幅提升数据采集效率,适用于大规模网页抓取。本文详解其原理与实现,涵盖任务队列、线程池、会话保持、异常处理、反爬对抗等核心技术,并提供可扩展的Python模板代码,助力高效稳定的数据采集实践。
230 0

推荐镜像

更多