【PyQt错误集 - 1】:PyQt调用多线程导致窗口异常退出的问题分析(进程已结束,退出代码 -1073741819 (0xC0000005))

本文主要是介绍【PyQt错误集 - 1】:PyQt调用多线程导致窗口异常退出的问题分析(进程已结束,退出代码 -1073741819 (0xC0000005)),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 问题分析
  • 解决方法

问题分析

运行以下程序:

def run_thread_WTD(self):threading.Thread(target=self.WTD).start()def WTD(self):word_path = self.word_path.text()# textBrowser为多行文本框QTextEditself.pycorrectorKenlm(word_path, textBrowser)# kenlm
def pycorrectorKenlm(self, word_path, textBrowser):error_counter_kenlm = 0try:m = Corrector(language_model_path='zh_giga.no_cna_cmn.prune01244.klm',custom_confusion_path_or_dict='my_custom_confusion.txt')#./ means current Pathexcept:textBrowser.append("Error")doc = docx.Document(word_path)for para in doc.paragraphs:if (para.text == ""):passelse:if (len(m.correct_batch([para.text])[0]['errors']) == 0):passelse:error_counter_kenlm += 1json_data = json.dumps(m.correct_batch([para.text])[0], sort_keys=False, indent=4, ensure_ascii=False)textBrowser.append(json_data)json_data_1 = json.loads(json_data)self.sourses = jsonpath(json_data_1, '$..source')self.targets = jsonpath(json_data_1, '$..target')textBrowser.append("\n")textBrowser.append(f"Chinese Total error: {error_counter_kenlm}")

运行后,PyQt主窗口界面卡死,一段时间后异常退出:

进程已结束,退出代码 -1073741819 (0xC0000005)

通过测试分析,发现出现异常的可能的原因:对于耗时长的函数,当采用多线程编程调用其函数,如果支线程频繁访问了界面对象可能会导致界面卡死,异常退出。

(在以上例子中,函数pycorrectorKenlm就不断的在访问界面对象textBrowser从而导致界面卡死。)

通过测试,发现在线程调用的函数(例:WTD)(包括线程调用的函数中所调用的函数)都不能频繁访问界面对象,否则可能会导致界面卡死,异常退出。

解决方法

以上述代码为例,将支线程中访问的界面对象去除,用一个临时变量保存数据,最终返回数据结果,同时编写一个QTimer函数,对返回的数据结果进行判断,返回值不为空,则在textBrowser中打印数据。(相当于开启两个线程)

修改后的程序:

def run_thread_WTD(self):self.process_info = []self.timer1.start(1000)threading.Thread(target=self.WTD).start()def WTD(self):word_path = self.word_path.text()# textBrowser为多行文本框QTextEditself.process_info = self.pycorrectorKenlm(word_path)def write_result_text(self):if self.process_info != []:for i in self.process_info:self.result_text.append(i)self.timer1.stop()self.process_info = []def pycorrectorKenlm(self, word_path):process_info = []error_counter_kenlm = 0try:m = Corrector(language_model_path='zh_giga.no_cna_cmn.prune01244.klm',custom_confusion_path_or_dict='my_custom_confusion.txt')#./ means current Pathexcept:process_info.append("Error")doc = docx.Document(word_path)for para in doc.paragraphs:if (para.text == ""):passelse:if (len(m.correct_batch([para.text])[0]['errors']) == 0):passelse:error_counter_kenlm += 1json_data = json.dumps(m.correct_batch([para.text])[0], sort_keys=False, indent=4, ensure_ascii=False)process_info.append(json_data)j	son_data_1 = json.loads(json_data)self.sourses = jsonpath(json_data_1, '$..source')self.targets = jsonpath(json_data_1, '$..target')process_info.append("\n")process_info.append(f"Chinese Total error: {error_counter_kenlm}")

这篇关于【PyQt错误集 - 1】:PyQt调用多线程导致窗口异常退出的问题分析(进程已结束,退出代码 -1073741819 (0xC0000005))的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820213

相关文章

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每