进程与线程概念和并行与并发概念

Posted 杀手不太冷!

tags:

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

进程与线程概念和并行与并发概念

进程与线程概念

进程:进程其实就相当于运行程序的一个实例,比如说运行记事本,这时就相当于是运行一个进程。有的程序可以运行多个进程实例,比如说记事本,你可以打开多个记事本;而有的程序只能运行一个进程实例,比如说网易云,你只能打开一个网易云音乐。

线程:线程存在于进程里面,一个进程可以有多个线程,每个线程其实内部都是由多条指令组成的,是一个指令流,指令流中的一条条指令以一定的顺序交给CPU执行。

这里写图片描述

并行与并发概念

并行:同一时刻,可以同时做多件事,并且这多件事互不干扰。比如如果你的cpu是双核的,那么每个cpu都可以在一个时刻调度一个线程,这两个线程同时执行,并且互不干扰,这就是并行。如下图:
在这里插入图片描述

并发:并发是一种并行的假象,为什么这样说呢?就是你从宏观来看,这几个线程是同时调用的,但其实每个时刻只有一个线程被调用,只不过cpu分片的时间很短,所以我们宏观上看不出来,就感觉它是同时进行的,其实它不是同时进行的。就比如你的cpu是单核的,那么每个分片时间内,你只能调度一个线程,只不过如果这个分片时间很短,你比如windows下cpu的时间分片是15毫秒,即每15毫秒cpu就会切换一个线程,这个时间是非常短的,我们感觉不出来,所以就觉得多个线程是同时进行的。如下图:
在这里插入图片描述

什么叫做cpu时间分片呢?就是程序中有多个线程,cpu会来回的切换每个线程,但是如何能够保证每个线程被调度的时间都是相同的呢?cpu会有一个时间分片,每一片时间都是相同的,如果时间到了,那么cpu就会从当前线程切换到下一个线程,这样就可以保证每个线程被调度的时间都是相同的了。

例子:

1.家庭主妇做饭,打扫卫生,给孩子喂奶,她一个人轮流交替做这件事,这时就是并发。

2.家庭主妇雇了个保姆,她们一起做这些事,这时既有并发吗,也有并行(这时会产生竞争,例如锅只有一口,一个人用锅时,另一个人就要等待)

3.雇了三个保姆,一个专门做饭,一个专打扫卫生,一个专喂奶,互不干扰,这就是并行

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

python进阶--多进程与多线程概念

Python--进程与线程

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

Java多线程原理+基础知识(超级超级详细)+(并发与并行)+(进程与线程)1

多线程进程并发并行同步异步伪并发真并发

JAVA多线程与多进程