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() 方法执行完毕或抛出未捕获异常。
相关推荐
云烟成雨TD3 小时前
Spring AI Alibaba 1.x 系列【69】Token 用量统计
java·人工智能·spring
JAVA9653 小时前
JAVA面试-并发篇 03-使用synchronized doublecheck实现单例有什么坑
java·单例模式·面试
在繁华处3 小时前
Java从零到熟练(四):面向对象基础
java·开发语言
小江的记录本5 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
在繁华处5 小时前
Java从零到熟练(三):流程控制
java·开发语言·python
唐青枫5 小时前
Java Optional 实战指南:优雅处理空值与链式转换
java
一起学开源5 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
逍遥德6 小时前
MQTT教程详解-04.SpringBoot集成MQTT(告别手动控制)
java·spring boot·物联网·中间件·iot·iotdb
语戚6 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
我命由我123457 小时前
Android 开发问题:MlKitException: An internal error occurred during initialization.
android·java·java-ee·android jetpack·android-studio·androidx·android runtime