子进程和线程之间的区别

时间:2016-05-25 07:16:41

标签: multithreading subprocess

子进程和线程有什么区别?我用谷歌搜索,但无法找到合适的答案。上面提供的答案链接区分了进程和线程,但我想知道子进程和线程之间的区别。由于子进程也是一个进程,它与进程和线程之间的差异大致相同,但我想知道子进程和线程之间是否存在某些特定的差异,这些差异不在进程和线程之间。

1 个答案:

答案 0 :(得分:6)

首先,我们必须了解Process的实际内容,然后是Thread,如果我们能够做到这一点,那么回答这个问题会更容易。

流程与主题

进程(有时也称为任务)是程序的执行(即运行)实例。 线程是轻量级进程 ,可以并行运行, 与父进程共享地址空间(即一系列内存位置)和其他资源(即创建它们的过程)。

以上部分取自此链接:http://www.linfo.org/context_switch.html

流程是执行中的程序。例如,当我们用C或C ++编写程序并编译它时,编译器会创建一个二进制代码原始代码和二进制代码都是程序。当我们实际运行二进制代码时,它就变成了一个进程。 流程是一个“主动”实体,而不是被认为是“被动”实体的程序。 单个程序可以在多次运行时创建许多进程,例如,当我们多次打开.exe或二进制文件时,许多实例开始(创建了许多进程)。

以上部分取自此链接:https://www.geeksforgeeks.org/gate-notes-operating-system-process-management-introduction/

进程是程序的实例(例如Jupyter notebook,Python解释器)。 处理生成线程(子流程)以处理子任务 ,例如读取击键,加载HTML页面,保存文件。线程存在于进程内部并共享相同的内存空间。

示例:Microsoft Word 当您打开Word时,您创建一个过程。当您开始键入时,该过程会生成线程:一个用于读取击键,另一个用于显示文本,一个用于自动保存文件,另一个用于突出显示拼写错误。通过生成多个线程,Microsoft利用空闲的CPU时间(等待击键或加载文件)并提高工作效率。

以上部分取自此链接:https://medium.com/@bfortuner/python-multithreading-vs-multiprocessing-73072ce5600b

Python为程序员提供线程和子进程库以进行多任务处理。两者的目的几乎相同,但我们将选择线程或子流程取决于我们想要什么。 对于IO绑定应用程序而言,线程可能已经足够好了,但不是CPU绑定应用程序,因为它只使用了单个CPU核心,因为Python的GIL和一个线程的失败会导致整个应用程序崩溃。

Subprocess适用于IO绑定应用程序和CPU绑定应用程序,但消耗更多内存。可以同时使用所有CPU核心(并行),单个进程的失败不会影响其他核心。

以上部分取自此链接:https://www.quora.com/For-multiprocessing-in-Python-which-library-should-I-use-threading-or-subprocess