java线程详解

一、线程的创建方式

Java 中创建线程主要有以下三种方式:

  1. 继承 Thread

    scala 复制代码
    public class MyThread extends Thread {
        @Override
        public void run() {
            System.out.println("Thread running by extending Thread");
        }
    }
    // 使用
    MyThread thread = new MyThread();
    thread.start();
  2. 实现 Runnable 接口(推荐,避免单继承限制)

    java 复制代码
    public class MyRunnable implements Runnable {
        @Override
        public void run() {
            System.out.println("Thread running by implementing Runnable");
        }
    }
    // 使用
    Thread thread = new Thread(new MyRunnable());
    thread.start();
  3. 实现 Callable 接口 (可返回结果,需配合 FutureTask

    typescript 复制代码
    public class MyCallable implements Callable<String> {
        @Override
        public String call() {
            return "Result from Callable";
        }
    }
    // 使用
    FutureTask<String> futureTask = new FutureTask<>(new MyCallable());
    Thread thread = new Thread(futureTask);
    thread.start();
    System.out.println(futureTask.get()); // 获取结果

二、线程的生命周期与状态

以下是使用 Mermaid 语法描述的 Java 线程状态变迁图,清晰展示状态之间的转换关系和触发条件:

scss 复制代码
实例化(new Thread())
Thread.start()
Object.wait()
Thread.join()
LockSupport.park()
Object.notify()
Object.notifyAll()
LockSupport.unpark()
Thread.sleep(long)
Object.wait(long)
Thread.join(long)
LockSupport.parkNanos()
LockSupport.parkUntil()
超时时间到
Object.notify()
LockSupport.unpark()
等待进入synchronized方法/块
(锁被其他线程占用)
获取到锁
执行完成(run()结束)
未捕获异常
NEW
RUNNABLE
系统调度选择执行
yield() 或系统调度
系统调度选择执行
RUNNING
READY
WAITING
TIMED_WAITING
BLOCKED
TERMINATED

状态说明

  1. NEWRUNNABLE

    • 触发条件 : 调用线程的 start() 方法。
  2. RUNNABLEBLOCKED

    • 触发条件 : 尝试进入 synchronized 块但锁被其他线程占用。
  3. BLOCKEDRUNNABLE

    • 触发条件 : 成功获取 synchronized 锁。
  4. RUNNABLEWAITING

    • 触发条件: 调用以下方法之一:

      • Object.wait()(需其他线程唤醒)
      • Thread.join()(等待目标线程终止)
      • LockSupport.park()(需其他线程 unpark())。
  5. WAITINGRUNNABLE

    • 触发条件 : 被唤醒(notify()/notifyAll())、目标线程终止或 LockSupport.unpark()
  6. RUNNABLETIMED_WAITING

    • 触发条件: 调用以下方法之一:

      • Thread.sleep(n)
      • Object.wait(timeout)
      • LockSupport.parkNanos(time)
  7. TIMED_WAITINGRUNNABLE

    • 触发条件: 超时时间到或被中断唤醒。
  8. RUNNABLETERMINATED

    • 触发条件 : run() 方法执行完毕或抛出未捕获异常。
相关推荐
yuriy.wang几秒前
Spring IOC源码篇五 核心方法obtainFreshBeanFactory.doLoadBeanDefinitions
java·后端·spring
凸头5 分钟前
解决慢SQL问题
java·mysql
脑壳疼___34 分钟前
若依 springboot websocket
java·spring
失散133 小时前
分布式专题——23 Kafka日志索引详解
java·分布式·云原生·架构·kafka
西红柿维生素3 小时前
CPU核心数&线程池&设计模式&JUC
java
云虎软件朱总3 小时前
配送跑腿系统:构建高并发、低延迟的同城配送系统架构解析
java·系统架构·uni-app
18538162800余+3 小时前
深入解析:什么是矩阵系统源码搭建定制化开发,支持OEM贴牌
java·服务器·html
李昊哲小课3 小时前
Spring Boot 基础教程
java·大数据·spring boot·后端
code123133 小时前
tomcat升级操作
java·tomcat
TanYYF4 小时前
HttpServletRequestWrapper详解
java·servlet