线程,进程。多进程,多线程。并发,并行的区别

Posted liliuguang

tags:

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

一:线程与进程 
1.概念 
线程:是程序执行流的最小单元,是系统独立调度和分配CPU(独立运行)的基本单位。 
进程:是资源分配的基本单位。一个进程包括多个线程。 
2.区别: 
1.线程与资源分配无关,它属于某一个进程,并与进程内的其他线程一起共享进程的资源。 
2.每个进程都有自己一套独立的资源(数据),供其内的所有线程共享。 
3.不论是大小,开销线程要更“轻量级” 
4.一个进程内的线程通信比进程之间的通信更快速,有效。(因为共享变量)

二.多线程与多进程 
多线程:同一时刻执行多个线程。用浏览器一边下载,一边听歌,一边看视频,一边看网页。。。 
多进程:同时执行多个程序。如,同事运行YY,QQ,以及各种浏览器。

三.并发与并行 
并发当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间 段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状。.这种方式我们称之为并发(Concurrent)。

并行:当系统有一个以上CPU时,则线程的操作有可能非并发。当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)。












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

并发 并行 同步 异步 多线程的区别

多线程面试题(2020)

多线程面试题(2020)

单核和多核,单进程和多进程,单线程与多线程

多线程

JAVA多线程与多进程