python – 线程和进程混合的奇怪行为
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – 线程和进程混合的奇怪行为,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1112字,纯文字阅读大概需要2分钟。
内容图文
我正在运行以下python代码:
import threading
import multiprocessing
def forever_print():
while True:
print("")
def main():
t = threading.Thread(target=forever_print)
t.start()
return
if __name__=='__main__':
p = multiprocessing.Process(target=main)
p.start()
p.join()
print("main process on control")
它终止了.
当我从新进程中解包main时,直接运行它,如下所示:
if name == '__main__':
main()
正如我想的那样,剧本永远存在.我错误地认为,假设t是非守护进程,p在第一种情况下不应该停止吗?
我基本上设置了这个小测试,因为我一直在开发一个应用程序,其中线程在子进程内生成,并且它已经显示出一些奇怪的行为(有时它会正常终止,有时它不会终止).从广义上讲,我想我想知道的是,当混合这两个python库时,是否存在某种“陷阱”.
我的运行环境:python 2.7 @ Ubuntu 14.04 LTS
解决方法:
目前,多处理工作进程创建的线程就像进程终止一样执行守护程序线程:工作进程退出而不等待它创建的线程终止.这是由于工作进程使用os._exit()关闭,这会跳过大多数正常的关闭处理(特别是跳过正常的退出处理代码(sys.exit()).join()的非守护进程线程.Threads).
最简单的解决方法是让工作进程显式地.join()他们创建的非守护进程线程.
有关于此行为的公开错误报告,但它没有取得多大进展:http://bugs.python.org/issue18966
内容总结
以上是互联网集市为您收集整理的python – 线程和进程混合的奇怪行为全部内容,希望文章能够帮你解决python – 线程和进程混合的奇怪行为所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。