多进程与多线程的区别

Posted 无恙_z

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多进程与多线程的区别相关的知识,希望对你有一定的参考价值。

今天七牛云的面试被问到了没答好,在此记录下加深印象

进程与线程的区别

先来说下进程与线程间的区别:

  1. 进程是一个独立功能的程序,而线程是进程中的其中一个功能(比如:你打开了QQ,QQ就是一个进程。然后你在QQ输入文字聊天,这个就是线程)。
  2. 进程是系统进行资源分配和调度的单位,而线程是 CPU 调度和分派的基本单位。
  3. 进程的资源是被线程共享的

多进程与多线程的区别

  1. 多进程的数据是分开的,所以多进程共享复杂,同步简单(需要用IPC);而多线程由于是共享一个线程的资源,所以多线程共享简单,同步复杂。
  2. 多进程占内存多,切换复杂,CPU 利用率低;而多线程占内存少,切换简单,CPU 利用率高。
  3. 多进程相互独立,所以可靠性高;多线程如果一个线程出问题的话可能导致整个进程都崩溃,所以可靠性低。
  4. 多进程创建销毁速度慢;多线程的创建销毁速度快

具体的话就看这张图吧,图片来源于此处
在这里插入图片描述

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

Linux多进程与多线程之间的区别

多线程与多进程的区别

多进程与多线程的区别

多进程与多线程的区别

多进程与多线程的区别

分析详解python多线程与多进程区别