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() 方法执行完毕或抛出未捕获异常。
相关推荐
lee_curry38 分钟前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣2 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿2 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
金銀銅鐵3 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
野生技术架构师4 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
小袁拒绝摆烂5 小时前
多表关联大平层转JSON树形结构
java·json
ja哇6 小时前
大厂面试高频八股
java·面试·职场和发展
yoyo_zzm6 小时前
Laravel6.x新特性全解析
java·spring boot·后端
Nick_zcy6 小时前
小说在线阅读网站和小说管理系统 · 功能全解析
java·后端·python·springboot·ruoyi