多线程第一课:进程、线程,并行,并发
1.基本概念
- 进程
进程可以理解为一个在内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程可以有多个线程。比如说在我们常用的Windows系统中,一个以exe结尾的程序就是一个进程。任务管理器中的进程:
- 线程
线程又被称为轻型进程或进程元。线程可以看做是每一个进程所要执行的一个个任务,因此一个进程可以有一个线程,一个进程也可以有很多很多线程多个线程之间是共享数据的。
同时,我们要注意的是:同类的多个线程共享进程的堆和方法区资源,但每个线程有自己的程序计数器、虚拟机栈和本地方法栈,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。
- 并行
定义是:同一时刻进程与进程同时执行。同时执行,这取决于CPU的逻辑处理器,而逻辑处理器很少,要执行的进程和线程却非常多,也正因如此,并发会比并行多得多。
任务管理器CPU截图: 我们很容易看到逻辑处理器只有8个,但正常使用的情况下进程和线程都非常的多。那么这就要用到我们下面要讲的并发了。
- 并发
定义是:一段时间内,线程交替运行。看似是同时运行,实际上是每个可运行线程去抢CPU的时间片段,交替地运行。我们电脑的大部分程序都是并发的,各个线程交替运行。
2.总结
举个通俗的例子:
并行:你吃饭吃到一半,突然电话来了,你可以同时打电话和吃饭,说明是并行。
并发:你吃饭吃到一半,突然电话来了,你需要停下来接电话,吃一口饭,说一句话,这样交替进行,这就是并发。
总的来说,进程之间是相互独立的,同一个进程中的所有线程共享进程的堆和方法区资源。一个进程可以并发多个线程,这些线程就好像是实现进程功能所需要的一个个方法。
(The end.)