浩gg教你学Java(六)——进程,线程,并行,并发(多线程第一课)

多线程第一课:进程、线程,并行,并发

1.基本概念

  • 进程

  进程可以理解为一个在内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程可以有多个线程。比如说在我们常用的Windows系统中,一个以exe结尾的程序就是一个进程。任务管理器中的进程:
在这里插入图片描述

  • 线程

  线程又被称为轻型进程进程元。线程可以看做是每一个进程所要执行的一个个任务,因此一个进程可以有一个线程,一个进程也可以有很多很多线程多个线程之间是共享数据的。
  同时,我们要注意的是:同类的多个线程共享进程的堆和方法区资源,但每个线程有自己的程序计数器、虚拟机栈和本地方法栈,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。

  • 并行

  定义是:同一时刻进程与进程同时执行。同时执行,这取决于CPU的逻辑处理器,而逻辑处理器很少,要执行的进程和线程却非常多,也正因如此,并发会比并行多得多。
  任务管理器CPU截图: 我们很容易看到逻辑处理器只有8个,但正常使用的情况下进程和线程都非常的多。那么这就要用到我们下面要讲的并发了。
在这里插入图片描述

  • 并发

  定义是:一段时间内,线程交替运行。看似是同时运行,实际上是每个可运行线程去抢CPU的时间片段,交替地运行。我们电脑的大部分程序都是并发的,各个线程交替运行。

2.总结

举个通俗的例子:
	并行:你吃饭吃到一半,突然电话来了,你可以同时打电话和吃饭,说明是并行。
	并发:你吃饭吃到一半,突然电话来了,你需要停下来接电话,吃一口饭,说一句话,这样交替进行,这就是并发。

  总的来说,进程之间是相互独立的,同一个进程中的所有线程共享进程的堆和方法区资源。一个进程可以并发多个线程,这些线程就好像是实现进程功能所需要的一个个方法。
(The end.)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值