博客
关于我
深入理解Java线程状态转移
阅读量:417 次
发布时间:2019-03-06

本文共 879 字,大约阅读时间需要 2 分钟。

线程状态转移过程详解

在Java编程中,线程的状态转移是理解线程调度机制的重要基础。本文将详细阐述线程在不同状态间的转移过程。

新建态到就绪态

新建态是线程被创建时的初始状态。线程在新建态时尚未执行start()方法,需要调用start()才能进入就绪态。就绪态是线程可以被操作系统调度执行的状态。线程从新建态转移到就绪态的方式包括:

  • 线程执行start()方法
  • 线程处于阻塞态,等待I/O操作完成
  • 线程处于等待队列,等待锁池通知
  • 就绪态到运行态

    从就绪态到运行态的过程非常简单。操作系统会随机选择一个处于就绪态的线程分配时间片,线程进入运行态开始执行任务。这种调度方式确保了多线程程序的公平执行。

    运行态到就绪态

    线程在运行态中执行完毕当前的时间片后,会自动转回就绪态,等待新的调度。这种自动转换是操作系统的一部分机制,确保线程能轮流执行。

    运行态到阻塞态

    线程在运行态中可能因多种原因进入阻塞态:

  • Thread.sleep():线程主动进入睡眠状态
  • t1.join():线程等待另一个线程完成
  • I/O操作完成:比如读写操作完成,线程等待下一步指令
  • 阻塞态到就绪态

    从阻塞态恢复到就绪态的过程通常由三种方式触发:

  • sleep()方法结束:线程恢复到就绪态
  • join()方法完成:等待线程完成后恢复到就绪态
  • I/O操作完成:线程等待操作的结果
  • 运行态到等待队列

    当线程占有对象锁并调用**wait()方法时,线程会进入等待队列,等待其他线程的notify()notifyAll()**通知才能恢复到锁池队列。

    等待队列到锁池队列

    线程在等待队列中,等待获得对象锁。当其他线程释放锁后,线程从等待队列转移到锁池队列,等待被操作系统调度。

    锁池队列到就绪态

    线程从锁池队列中获取对象锁后,进入就绪态,等待操作系统调度进入运行态。

    运行态到死亡态

    线程在运行态中执行完毕任务后,进入死亡态。死亡态是一种终态,一旦进入无法恢复,线程终止。

    通过以上状态转移过程,可以清晰地了解线程调度的机制和原理。理解这些状态转移,对于优化多线程程序性能、调试线程问题都至关重要。

    转载地址:http://frzuz.baihongyu.com/

    你可能感兴趣的文章
    NLP的神经网络训练的新模式
    查看>>
    NLP采用Bert进行简单文本情感分类
    查看>>
    NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
    查看>>
    NLP:使用 SciKit Learn 的文本矢量化方法
    查看>>
    Nmap扫描教程之Nmap基础知识
    查看>>
    Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
    查看>>
    NMAP网络扫描工具的安装与使用
    查看>>
    NMF(非负矩阵分解)
    查看>>
    nmon_x86_64_centos7工具如何使用
    查看>>
    NN&DL4.1 Deep L-layer neural network简介
    查看>>
    NN&DL4.3 Getting your matrix dimensions right
    查看>>
    NN&DL4.8 What does this have to do with the brain?
    查看>>
    nnU-Net 终极指南
    查看>>
    No 'Access-Control-Allow-Origin' header is present on the requested resource.
    查看>>
    NO 157 去掉禅道访问地址中的zentao
    查看>>
    no available service ‘default‘ found, please make sure registry config corre seata
    查看>>
    no connection could be made because the target machine actively refused it.问题解决
    查看>>
    No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>