python – 我应该使用fork还是thread?

前端之家收集整理的这篇文章主要介绍了python – 我应该使用fork还是thread?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在我的脚本中,我有一个函数foo,它基本上使用pynotify在15分钟的时间间隔之后反复通知用户.
def foo:
    while True:
        """Does something"""
        time.sleep(900)

我的主要脚本必须与用户&做所有其他事情所以我不能调用foo()函数.直.

Whats the better way of doing it and why?
Using fork or threads?

解决方法

我不会告诉你使用哪一个,但这里有一些优点:

线程可以比进程更快地启动,并且线程使用比进程更少的操作系统资源,包括内存,文件句柄等.线程还为您提供了通过共享变量进行通信的选项(尽管许多人会说这比一个更不利于优势 – 见下文).

每个进程都有自己独立的内存和变量,这意味着进程通常通过相互发送消息进行通信.这比线程通过共享内存进行通信要容易得多.进程也可以真正同时运行,因此如果您有多个cpu核心,您可以让所有进程忙于使用进程.在Python *中,global interpreter lock可以防止线程多次使用多个核心.

* – 也就是CPython,如果你去http://python.org并下载Python就可以获得Python的实现.其他Python实现(例如Jython)不一定禁止Python同时在多个cpu上运行线程.感谢@EOL的澄清.

猜你在找的Python相关文章