• 【学习笔记】线程的生命周期和状态


    CSDN话题挑战赛第2期
    参赛话题:学习笔记

    线程的生命周期?线程有几种状态

    五种状态

    线程有创建,就绪,运行、阻塞和死亡状态。

    阻塞三种状态:

    等待阻塞

    运行的线程执行wait方法,该线程会释放占用的所有资源,JVM会把该线程放入“等待池”中。进入这个状态后,是不能自动唤醒的,必须依靠其他线程调用notify或notifyAll方法才能被唤醒,wait是object类的方法

    同步阻塞

    运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入“锁池”中。

    其他阻塞:

    运行的线程执行sleep或join方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep状态超时、join等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。sleep是Thread类的方法

    新建状态(New)

    新创建了一个线程对象。

    就绪状态(Runnable)

    线程对象创建后,其他线程调用了该对象的start方法。该状态的线程位于可运行线程池中,变得可运行,等待获取CPU的使用权。

    运行状态(Running)

    就绪状态的线程获取了CPU,执行程序代码。

    阻塞状态(Blocked)

    阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。

    死亡状态(Dead)

    线程执行完了或者因异常退出了run方法,该线程结束生命周期。

    sleep()、wait()、join()、yield()的区别

    锁池

    所有需要竞争同步锁的线程都会放在锁池当中,比如当前对象的锁已经被其中一个线程得到,则其他线程需要在这个锁池进行等待,当前面的线程释放同步锁后锁池中的线程去竞争同步锁,当某个线程得到后会进入就绪队列进行等待cpu资源分配。

    等待池

    当我们调用wait()方法后,线程会放到等待池当中,等待池的线程是不会去竞争同步锁。只有调用了notify()或notifyAll()后等待池的线程才会开始去竞争锁,notify()是随机从等待池选出一个线程放到锁池,而notifyAll()是将等待池的所有线程放到锁池当中

    1、sleep 是 Thread 类的静态本地方法,wait 则是 Object 类的本地方法。

    2、sleep方法不会释放lock,但是wait会释放,而且会加入到等待队列中。

    sleep就是把cpu的执行资格和执行权释放出去,不再运行此线程,当定时时间结束再取回cpu资源,参与cpu 的调度,获取到cpu资源后就可以继续运行了。而如果sleep时该线程有锁,那么sleep不会释放这个锁,而 是把锁带着进入了冻结状态,也就是说其他需要这个锁的线程根本不可能获取到这个锁。也就是说无法执行程 序。如果在睡眠期间其他线程调用了这个线程的interrupt方法,那么这个线程也会抛出 interruptexception异常返回,这点和wait是一样的。
    
    • 1

    3、sleep方法不依赖于同步器synchronized,但是wait需要依赖synchronized关键字。

    4、sleep不需要被唤醒(休眠之后推出阻塞),但是wait需要(不指定时间需要被别人中断)。

    5、sleep 一般用于当前线程休眠,或者轮循暂停操作,wait 则多用于多线程之间的通信。

    6、sleep 会让出 CPU 执行时间且强制上下文切换,而 wait 则不一定,wait 后可能还是有机会重新竞争到锁继续执行的。

    yield()执行后线程直接进入就绪状态,马上释放了cpu的执行权,但是依然保留了cpu的执行资格,所以有可能cpu下次进行线程调度还会让这个线程获取到执行权继续执行

    join()执行后线程进入阻塞状态,例如在线程B中调用线程A的join(),那线程B会进入到阻塞队列,直到线程A结束或中断线程

    image.png

    image.png

  • 相关阅读:
    xss.haozi.me靶场练习
    NetSuite海鲜书 - 知识会汇编 用户篇 2023
    集合框架面试题
    Mybatis概述及入门
    NDepend v2022.2.1.9665 专业版
    CSS 3之菜单的横竖转换
    java springboot 实现 对象或对象数组 转为 前端可解析的JSON字符串格式
    uniapp vue3 裁剪头像(ksp-cropper) 支持旋转 和 缩放
    六十八、vue高级
    亚马逊黑色星期五什么时候开始?
  • 原文地址:https://blog.csdn.net/weixin_43719843/article/details/126900336