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() 方法执行完毕或抛出未捕获异常。
相关推荐
时艰.3 分钟前
Java 并发编程 — 并发容器 + CPU 缓存 + Disruptor
java·开发语言·缓存
丶小鱼丶8 分钟前
并发编程之【优雅地结束线程的执行】
java
市场部需要一个软件开发岗位13 分钟前
JAVA开发常见安全问题:Cookie 中明文存储用户名、密码
android·java·安全
忆~遂愿17 分钟前
GE 引擎进阶:依赖图的原子性管理与异构算子协作调度
java·开发语言·人工智能
MZ_ZXD00122 分钟前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
PP东24 分钟前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
ManThink Technology29 分钟前
如何使用EBHelper 简化EdgeBus的代码编写?
java·前端·网络
invicinble33 分钟前
springboot的核心实现机制原理
java·spring boot·后端
人道领域42 分钟前
SSM框架从入门到入土(AOP面向切面编程)
java·开发语言
大模型玩家七七1 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习