multithreading - 子进程和线程的区别

标签 multithreading subprocess

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

最佳答案

首先,我们必须了解 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 绑定(bind)的应用程序可能足够好,但不是 CPU 绑定(bind)的应用程序,因为它一次只使用一个 CPU 核心,因为 Python 的 GIL 和一个线程的失败会使整个应用程序崩溃。

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

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

关于multithreading - 子进程和线程的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37430255/

相关文章:

Java 线程可见性 - 无需显式同步的可见性最佳实践

python - Python 中的线程子进程

python - 对于 subprocess.stderr=STDOUT - stdout=PIPE 比 stdout ="a_file_name"更好吗?

c++ - 访问其他线程堆栈变量如何在 C++ 中工作?

java - 并行向 Neo4j 数据库添加关系

python - 如何将 "subprocess.call"的输出捕获到文件中?

python-3.x - 在远程服务器上执行 tensorflow python3,子进程无法解释所有 tensorflow 输入 args。导入错误 : No module named 'scripts'

python - subprocess.communicate() 在写入输入后是否关闭标准输入?

c# - 出现错误 - System.InvalidOperationException 未处理

c++ - 使用类特定的 set_new_handler