子进程和线程的区别

Posted

技术标签:

【中文标题】子进程和线程的区别【英文标题】:Difference between subprocess and thread 【发布时间】:2016-09-22 15:38:28 【问题描述】:

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

【问题讨论】:

What is the difference between a process and a thread的可能重复 你的意思是“同一个进程的”吗? @sameerkn 是的,你可能会这么认为。 @Fresherdeveloper:为什么您认为子流程和流程在这种情况下会有所不同? 【参考方案1】:

首先,我们必须了解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 和一个线程的失败会导致整个应用程序崩溃。

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

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

【讨论】:

以上是关于子进程和线程的区别的主要内容,如果未能解决你的问题,请参考以下文章

什么是进程?和线程区别?

python多进程和多线程的区别

关于守护进程和守护线程的区别

python(33)多进程和多线程的区别

python 多线程和多进程的区别 mutiprocessing theading

主进程被kill或者错误退出,子线程还在跑怎么处理