hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝
在Java中,线程的调用方法主要包括以下几种方式,每种方式适用于不同的场景和需求:
Thread
类通过继承 Thread
类并重写 run()
方法,直接调用线程的 start()
方法启动线程。
class MyThread extends Thread {
@Override
public void run() {
System.out.println("Thread running by extending Thread");
}
}
// 调用方式
public class Main {
public static void main(String[] args) {
MyThread thread = new MyThread();
thread.start(); // 启动线程,执行run()
}
}
Thread
后无法继承其他类。Runnable
接口实现 Runnable
接口,将任务逻辑写入 run()
方法,然后将实例传递给 Thread
对象。
class MyRunnable implements Runnable {
@Override
public void run() {
System.out.println("Thread running by implementing Runnable");
}
}
// 调用方式
public class Main {
public static void main(String[] args) {
Thread thread = new Thread(new MyRunnable());
thread.start();
}
}
Callable
接口 + Future
通过 Callable
定义带返回值的任务,结合 ExecutorService
提交任务,并通过 Future
获取结果。
import java.util.concurrent.*;
class MyCallable implements Callable<String> {
@Override
public String call() throws Exception {
return "Result from Callable";
}
}
public class Main {
public static void main(String[] args) throws Exception {
ExecutorService executor = Executors.newSingleThreadExecutor();
Future<String> future = executor.submit(new MyCallable());
System.out.println(future.get()); // 阻塞获取结果
executor.shutdown();
}
}
Executor
框架)通过线程池管理线程生命周期,避免频繁创建/销毁线程的开销。
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
public static void main(String[] args) {
// 创建固定大小的线程池
ExecutorService executor = Executors.newFixedThreadPool(3);
// 提交Runnable任务
executor.execute(() -> {
System.out.println("Task executed by thread pool");
});
executor.shutdown(); // 关闭线程池
}
}
newFixedThreadPool
:固定线程数,适用于负载稳定的场景。newCachedThreadPool
:线程数自动扩展,适合短时异步任务。newScheduledThreadPool
:支持定时或周期性任务。newSingleThreadExecutor
:单线程顺序执行任务。简化线程创建的语法,适用于快速实现简单任务。
public class Main {
public static void main(String[] args) {
// 匿名内部类(Runnable)
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("Anonymous Runnable");
}
}).start();
// Lambda表达式(Java 8+)
new Thread(() -> System.out.println("Lambda Runnable")).start();
}
}
ScheduledExecutorService
)用于执行定时或周期性任务。
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class Main {
public static void main(String[] args) {
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
// 延迟1秒后执行
scheduler.schedule(() -> System.out.println("Delayed task"), 1, TimeUnit.SECONDS);
// 周期性任务(首次延迟2秒,之后每3秒执行一次)
scheduler.scheduleAtFixedRate(() -> System.out.println("Periodic task"), 2, 3, TimeUnit.SECONDS);
}
}
CompletableFuture
,Java 8+)通过链式调用处理异步任务,支持回调和非阻塞操作。
import java.util.concurrent.CompletableFuture;
public class Main {
public static void main(String[] args) {
CompletableFuture.supplyAsync(() -> "Async Result")
.thenAccept(result -> System.out.println(result))
.join(); // 等待异步任务完成
}
}
方法 | 核心优势 | 典型场景 |
---|---|---|
继承 Thread |
简单直接 | 快速测试或简单任务 |
实现 Runnable |
解耦任务与线程,支持资源共享 | 多线程共享任务逻辑 |
实现 Callable |
支持返回值和异常 | 需要异步结果的计算任务 |
线程池 | 资源复用,高效管理线程 | 高并发、资源受限的系统 |
CompletableFuture |
异步编程,链式调用 | 复杂异步任务编排 |
根据具体需求选择合适的方法:
Runnable
+ Thread
或 Lambda。Callable
+ Future
或 CompletableFuture
。newFixedThreadPool
)。ScheduledExecutorService
。