多进程与多线程的区别
Posted 无恙_z
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多进程与多线程的区别相关的知识,希望对你有一定的参考价值。
今天七牛云的面试被问到了没答好,在此记录下加深印象
进程与线程的区别
先来说下进程与线程间的区别:
- 进程是一个独立功能的程序,而线程是进程中的其中一个功能(比如:你打开了QQ,QQ就是一个进程。然后你在QQ输入文字聊天,这个就是线程)。
- 进程是系统进行资源分配和调度的单位,而线程是 CPU 调度和分派的基本单位。
- 进程的资源是被线程共享的
多进程与多线程的区别
- 多进程的数据是分开的,所以多进程共享复杂,同步简单(需要用IPC);而多线程由于是共享一个线程的资源,所以多线程共享简单,同步复杂。
- 多进程占内存多,切换复杂,CPU 利用率低;而多线程占内存少,切换简单,CPU 利用率高。
- 多进程相互独立,所以可靠性高;多线程如果一个线程出问题的话可能导致整个进程都崩溃,所以可靠性低。
- 多进程创建销毁速度慢;多线程的创建销毁速度快
具体的话就看这张图吧,图片来源于此处。
以上是关于多进程与多线程的区别的主要内容,如果未能解决你的问题,请参考以下文章