当前位置: 首页 > article >正文

【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为多行文本框QTextEdit
    self.pycorrectorKenlm(word_path, textBrowser)

 # kenlm
def pycorrectorKenlm(self, word_path, textBrowser):
    error_counter_kenlm = 0
    try:
        m = Corrector(language_model_path='zh_giga.no_cna_cmn.prune01244.klm',
                      custom_confusion_path_or_dict='my_custom_confusion.txt')#./ means current Path
    except:
        textBrowser.append("Error")

    doc = docx.Document(word_path)
    for para in doc.paragraphs:
        if (para.text == ""):
            pass
        else:
            if (len(m.correct_batch([para.text])[0]['errors']) == 0):
                pass
            else:
                error_counter_kenlm += 1
                json_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为多行文本框QTextEdit
    self.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 = 0
    try:
        m = Corrector(language_model_path='zh_giga.no_cna_cmn.prune01244.klm',
                      custom_confusion_path_or_dict='my_custom_confusion.txt')#./ means current Path
    except:
        process_info.append("Error")

    doc = docx.Document(word_path)
    for para in doc.paragraphs:
        if (para.text == ""):
            pass
        else:
            if (len(m.correct_batch([para.text])[0]['errors']) == 0):
                pass
            else:
                error_counter_kenlm += 1
                json_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}")

http://www.kler.cn/a/271813.html

相关文章:

  • llama.cpp LLM_ARCH_DEEPSEEK and LLM_ARCH_DEEPSEEK2
  • 如何学习Java后端开发
  • 自动驾驶中的多传感器时间同步
  • Autosar-Os是怎么运行的?(多核系统运行)
  • 简易CPU设计入门:控制总线的剩余信号(二)
  • 游戏策划的分类
  • 小蓝的漆房——算法思路
  • Blocks —— 《Objective-C高级编程 iOS与OS X多线程和内存管理》
  • 通过对话式人工智能实现个性化用户体验
  • 论文阅读——GeoChat(cvpr2024)
  • Linux运维相关基础知识
  • 030—pandas 对数据透视并将多层索引整合为一列
  • Sass学习记录
  • 有参转录组分析 |基因组信息下载和FQ数据过滤教程
  • ts版本微信小程序在wxml保存文件不刷新页面的解决办法
  • QML与C++通信
  • 面向对象编程第三式: 多态 (Java篇)
  • 【linux】搜索所有目录和子目录下的包含.git的文件并删除
  • 外包干了9天,技术退步明显。。。。。
  • 开源模型应用落地-qwen模型小试-调用Lora模型-进阶篇(七)
  • STM32输入捕获频率和占空比proteus仿真失败
  • Microsoft VBA Excel 规律的Text文件转工作表Sheet
  • XDP学习笔记
  • C语言基础之输入输出
  • MongoDB从0到1:高效数据使用方法
  • python--剑指offer--10- I. 斐波那契数列