为什么我们必须在Python中的非守护进程上使用join方法 - python

根据守护程序线程/进程的定义,它们不会阻止主线程/进程退出,而主线程/进程只有在其非守护程序线程退出后才会退出。

如果是这种情况,为什么我们要关心在线程/进程上调用threading.join()方法或multiprocessing.join()方法。

我不确定我对线程和进程的假设是写还是不写。如果不是,请指出正确的方向。

感谢您的任何答案。

参考方案

multiprocessing Programming Guidelines

  加入僵尸进程
  
  在Unix上,当进程完成但尚未加入时,它就变成了僵尸。永远不要有太多,因为每次启动新进程(或调用active_children()时),所有尚未加入的已完成过程都将加入。同时调用已完成流程的Process.is_alive将加入该流程。即便如此,将您启动的所有过程明确地加入也可能是一个好习惯。

UNIX操作系统要求过期的进程被明确地“垃圾收集”。忽略它会导致与不关闭文件时类似的问题。您将慢慢泄漏空的过程表,直到没有更多可用表并且您的应用程序将崩溃。

不幸的是,multiprocessing模块旨在重现threading API,因此使用的术语有时会引起混淆。 UNIX中的multiprocessing.Process.join与低级C wait函数相似。

如果不想阻止等待进程到期,可以通过将join的超时时间设置为0或使用multiprocessing.active_children API来定期轮询已到期的进程。无论如何,通常将daemon标志设置为True

Python:如何停止多线程的numpy? - python

我知道这似乎是一个荒谬的问题,但是我必须在与部门中其他人共享的计算服务器上定期运行作业,当我开始10个作业时,我真的希望它只占用10个核心而不是更多;我不在乎每次运行一个内核所需的时间是否更长:我只是不想让它侵犯其他人的领土,这将需要我放弃工作等等。我只想拥有10个核心,仅此而已。更具体地说,我在基于Python 2.7.3和numpy 1.6.1的Redh…

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python:图像处理可产生皱纹纸效果 - python

也许很难描述我的问题。我正在寻找Python中的算法,以在带有某些文本的白色图像上创建皱纹纸效果。我的第一个尝试是在带有文字的图像上添加一些真实的皱纹纸图像(具有透明度)。看起来不错,但副作用是文本没有真正起皱。所以我正在寻找更好的解决方案,有什么想法吗?谢谢 参考方案 除了使用透明性之外,假设您有两张相同尺寸的图像,一张在皱纹纸上明亮,一张在白色背景上有深…

Python uuid4,如何限制唯一字符的长度 - python

在Python中,我正在使用uuid4()方法创建唯一的字符集。但是我找不到将其限制为10或8个字符的方法。有什么办法吗?uuid4()ffc69c1b-9d87-4c19-8dac-c09ca857e3fc谢谢。 参考方案 尝试:x = uuid4() str(x)[:8] 输出:"ffc69c1b" Is there a way to…

Python:无法识别Pip命令 - python

这是我拍摄的屏幕截图。当我尝试在命令提示符下使用pip时,出现以下错误消息:pip无法识别为内部或外部命令,可操作程序或批处理文件。我已经检查了这个线程:How do I install pip on Windows?我所能找到的就是我必须将"C:\PythonX\Scripts"添加到我的类路径中,其中X代表python版本。如您在我的…