天增的博客
首页
博客
  • 分布式解决方案
  • Java并发工具包
  • redis
  • LeetCode
  • 系统设计
  • JVM体系
Github (opens new window)
Rss (opens new window)
  • zh-CN
  • en-US
首页
博客
  • 分布式解决方案
  • Java并发工具包
  • redis
  • LeetCode
  • 系统设计
  • JVM体系
Github (opens new window)
Rss (opens new window)
  • zh-CN
  • en-US
  • Java并发工具包
  • 并发基础
    • 线程基础
      • Thread的状态
        • New
        • Runable
        • 阻塞态
        • Watting
      • 进程与线程
      • 正确停止线程的方式
      • Thread的实现方式
      • waitnotifynotifyAll
      • 生产者消费者模型
    • 线程安全
      • 线程不安全
      • 线程安全
      • 需要注意线程安全问题的情况
  • 并发工具
    • 线程协作
      • Semaphore信号量
      • CountDownLatch详解
      • 使用CompletableFuture解决旅游平台问题
      • 使用CyclicBarrier解决团建问题
    • Future
      • Future主要功能
      • FutureTask源码分析
    • ThreadLocal
      • ThreadLocal内存泄漏
      • ThreadLocal使用场景
    • 原子类
      • 原子类的作用概览
      • 原子类的性能分析
    • 阻塞队列
      • 常见的阻塞队列
      • 阻塞队列的常用方法
      • 什么是阻塞队列
    • 并发容器
      • HashMap
      • CopyOnWriteArrayList
      • ConcurrentHashMap详解
    • 线程池
      • 为什么多线程会带来性能问题
      • 线程池的优势
      • 创建线程池的参数
        • 如何设置线程数
      • 线程池线程复用原理
      • ForkJoin框架
    • 各种锁
      • 锁的种类和特点
        • 公平锁非公平锁
        • 自旋锁非自旋锁
        • 共享锁独占锁
        • 乐观锁和悲观锁
      • JVM锁优化
      • synchronized和Lock的对比
      • lock的常用方法
  • 底层原理
    • CAS原理
    • AQS框架
    • 伪共享
    • java内存模型
      • Java内存模型介绍
      • happens-before规则
  • topic
  • Java并发工具包
  • 并发基础
  • 线程基础
  • Thread的状态
2022-04-21
目录

Thread的状态

# Thread的状态

image-20211101163645288

# New

new状态标识Thread已经创建了,也就是new Thread() ,但是没有调用start方法。

一旦调用start方法,状态就会从New 转换成 Runable

# Runable

Java中的Runable状态,对应着操作系统中的两种状态Running 或者 Ready

Java重处于Runable中的线程,有可能处于正在执行的状态,也有可能处于没有正在执行等待分配CPU资源

# 阻塞态

# Block

从Runable进入到Block只会有一种情况,在Synchronized修饰的代码运行时没有获取到monitor锁的时候,会进入Block状态

# Timed Watting

进入timed watting有三种可能性

  1. 设置timeout参数的Object.wait()
  2. 设置timeout参数的Thread.join()
  3. LockSuport.parkUntil(timeout)或LockSuport.parkNanos(timeout)方法

# Watting

进入watting有三种可能性

  1. 没有设置timeout参数的Object.wait()
  2. 没有设置timeout参数的Thread.join()
  3. LockSuport.park()方法

如果其他线程调用notify或者notifyAll方法来唤醒线程,会直接进入到block状态。因为唤醒watting的线程必须要持有monitor,所以处于watting状态的线程被唤醒时拿不到monitor锁则会进入block状态

最近更新
01
以 root 身份启动 transmission-daemon
12-13
02
Debian系统安装qbittorrent-nox
12-09
03
LXC Debain12安装zerotier并实现局域网自动nat转发
07-29
更多文章>
Theme by Vdoing | Copyright © 2015-2024 天增 | 苏ICP备16037388号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式