【无标题】线程的生命周期;并发并行的区别

线程的生命周期的理解;并行并发的理解

一:线程的生命周期的理解

一 :线程的生命周期
1 .线程的生命周期(5)
新建:创建线程对象
就绪:有执行的资格没有执行的权力
运行:有执行资格和执行的权力
阻塞:没有执行的资格和执行的权力;有些操作可以将阻塞状态的线程变为就绪状态
结束(死亡):线程结束,线程对象变成垃圾,等待被回收的过程

解释阻塞和就绪状态的区别:
比如我们去食堂打饭,在队伍里面的人可以打到饭,但是还没有轮到他打饭,我们可以称之在就绪的状态,在队伍外面的人不能打到饭,(相当于是处在阻塞的状态),当通过某些原因,队伍外面的人可能进队伍排队进行打饭的操作,因此对应(通过某些操作可以将阻塞状态变为就绪状态)

图片解释:
在这里插入图片描述线程的生命周期(6)
JVM的线程的运行状态

在这里插入图片描述
NEW:
线程刚被创建还未被启动
RUNNABLE:
线程的可运行状态,有可能在等待操作系统当中的其他资源,比如处理器等等
BLOCKED:
受阻塞并且正在等待监视器的一种线程的状态
WAITING:
某一等待线程的线程状态。线程正在无期限地等待另一个线程来执行某一个特定的操作,
TIME_WAITING:
指定时间的等待线程的状态,线程在规定时间等待另一个线程来执行某一个特定的操作
TERMINGATED:
线程的终止状态

线程具有的七种基本状态(在加上代码进行的分析)
新建状态(New):至今尚未启动的线程的状态。线程刚被创建,但尚未启动。如:Thread t = new Thread();创建一个线程的实例对象

**就绪状态(runnable):**当线程调用t.start()方法的时候线程进入就绪状态,处于就绪状态的线程,并不是说明调用了start方法,线程就一定会去执行,只能说线程做好了准备,等待CPU的执行调度

无限期等待(Waiting):位于对象等待池中的阻塞状态(Blocked in object’s wait pool):当线程处于运行状态时,如果执行了某个对象的wait()方法,Java虚拟机就会把线程放到这个对象的等待池中,这涉及到“线程通信”的内容。处于这种状态的线程不会被分配处理器执行时间它们要等待被其他线程显示唤醒

限期等待(Timed Waiting):处于这种状态的线程也不会被分配处理器执行时间,不过无须等待其他线程显示唤醒,在一定时间后它们由系统自动唤醒

阻塞状态(Blocked):处于运行状态中的线程由于某种(当线程处于运行状态时,想要获得某个对象的同步锁,但是该对象已经被其他对象获取同步锁,在运行状态时候,暂时放弃了CPU的调度和使用的权力,此时就会进入阻塞状态

死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

注意:线程就是在就绪,运行,阻塞之间相互转换的

二:并行并发的理解

并行:同一个时间有多少个处理器来处理事件,其实通俗的理解就是在同一时间可以执行多少任务(例如:小李边吃饭边玩手机)
例子:我们可以用食堂打饭的例子来解释并行的概念,在食堂打饭当中,食堂的窗口的数量的多少,就代表了并行量的多少(就是有多少事件可以同事进行)

并发:代表的是一个处理器,单位时间处理任务的个数(例如:小李快速的切换吃饭和玩手机这两件事情,切换的时间频率较高,看起来就像是在执行同一种事情)
例子:食堂打饭当中,单位时间一个阿姨给多少个人打饭,其实就可以看作并发的能力

总结:从食堂打饭可以看出,就打饭这件事情而言,要将1000个人的饭打完,不仅和窗口的数量有关,阿姨的打饭的速度有关。因此在电脑处理相同量的任务的时候也是如此,任务的处理的快慢不仅和处理器的数量有关,也和处理器本身的处理的效率息息相关

创作不易,如果各位看官觉得有用的话:希望点赞,转发,收藏,在加关注哦

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值