多进程Pipe包装器损坏:某些东西挂了 V5

问题描述

增强的Python多处理数据管道包装器

这是目标...

客观

这是我正在从事的一个大型项目。这是重要的部分,它将大大简化程序中的报告传输。该程序针对数百万个输入测试功能,并使用多重处理来加快处理速度。 Source code on Pastebin

目标和利益

简单地说,multiprocessing.Pipe()不足。它应该能够处理大量字符串并在发送方和接收方之间切换进程执行。我写这是为了实现:

  • 自动错误处理
  • 传输错误分类
  • 数据传输分块和重组
  • 无限的数据传输大小
  • 流程同步
  • 简单抽象以增强可用性

问题

它有一个我找不到的怪异错误。几天后,还有大量文档,但它不是固定的。我已经离开了很多调试行。尝试输入“ hi”:您不会看到“ Receiver.Test:Output:hi”,但应该看到。再试一次,它会挂起:Sample output

由亲爱的朋友解决。

测试

GPE有效。前两个测试都可以工作。对于测试1,此source code正确且一致地输出these results。对于测试2,此source code正确输出了类似these results的内容。对于测试3,此source code正确输出类似these results的内容。

请!

是时候寻求帮助了。它是一个较大项目的一部分。公平地说,有很多代码行。这应该是multiprocessing模块的一部分。我很谦虚有人可以告诉我吗?请?有人吗?

没人回答...

解决方法

问题

receive_oscillate中,yield from似乎永远不会消失。

注释

此外,深层嵌套的函数和一个衬里复合条件对Python而言并不是特质。此外,分解深层嵌套的功能并添加自动化的单元测试将有助于减少错误并简化维护。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...