当前位置: 首页 > news >正文

Java高频面试之并发编程-05

hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝🐶

面试官:线程有哪些调度方法?

在Java中,线程的调用方法主要包括以下几种方式,每种方式适用于不同的场景和需求:


1. 继承 Thread

通过继承 Thread 类并重写 run() 方法,直接调用线程的 start() 方法启动线程。

实现步骤
class MyThread extends Thread {@Overridepublic 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()}
}
特点
  • 优点:简单直接。
  • 缺点:Java是单继承,继承 Thread 后无法继承其他类。
  • 适用场景:简单任务,无需共享资源。

2. 实现 Runnable 接口

实现 Runnable 接口,将任务逻辑写入 run() 方法,然后将实例传递给 Thread 对象。

实现步骤
class MyRunnable implements Runnable {@Overridepublic 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();}
}
特点
  • 优点:避免单继承限制,任务与线程解耦,适合资源共享(如多个线程执行同一任务)。
  • 适用场景:多线程共享同一任务逻辑。

3. 实现 Callable 接口 + Future

通过 Callable 定义带返回值的任务,结合 ExecutorService 提交任务,并通过 Future 获取结果。

实现步骤
import java.util.concurrent.*;class MyCallable implements Callable<String> {@Overridepublic 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();}
}
特点
  • 优点:支持返回值,可抛出异常。
  • 适用场景:需要异步结果的任务(如计算密集型操作)。

4. 线程池(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:单线程顺序执行任务。
特点
  • 优点:资源复用、控制并发数、提供任务队列。
  • 适用场景:高并发、资源受限的系统。

5. 匿名内部类/Lambda表达式

简化线程创建的语法,适用于快速实现简单任务。

实现方式
public class Main {public static void main(String[] args) {// 匿名内部类(Runnable)new Thread(new Runnable() {@Overridepublic void run() {System.out.println("Anonymous Runnable");}}).start();// Lambda表达式(Java 8+)new Thread(() -> System.out.println("Lambda Runnable")).start();}
}
特点
  • 优点:代码简洁。
  • 适用场景:快速测试或简单任务。

6. 定时任务(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);}
}

7. 异步编程(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 + FutureCompletableFuture
  • 高并发场景:优先使用线程池(如 newFixedThreadPool)。
  • 定时任务:选择 ScheduledExecutorService

在这里插入图片描述

相关文章:

  • LDO手册看点
  • 交易所开发:构建高效数字交易枢纽
  • C++与C
  • Redis在SpringBoot中的使用
  • Uniapp:swiper(滑块视图容器)
  • ubuntu20.04 远程桌面Xrdp方式
  • AR/VR衍射光波导性能提升遇阻?OAS光学软件有方法
  • AOSP Android14 Launcher3——RecentsView最近任务数据加载
  • Java面试实战:从Spring Boot到微服务的深入探讨
  • 双周报Vol.70: 运算符重载语义变化、String API 改动、IDE Markdown 格式支持优化...多项更新升级!
  • 用Java实现简易区块链:从零开始的探索
  • 智能电网第1期 | 工业交换机在变电站自动化系统中的作用
  • 【云馨AI-大模型】Dify 1.2.0:极速集成 SearXNG,畅享智能联网搜索新境界,一键脚本轻松部署SearXNG
  • 基于STM32、HAL库的MCP41010T数字电位器驱动程序设计
  • idea快捷键 Project tool window
  • 【Linux网络与网络编程】07.应用层协议HTTPS
  • 眼镜眨巴眨巴-一步几个脚印从头设计数字生命2——仙盟创梦IDE
  • 国产紫光同创FPGA实现SDI视频编解码+图像缩放,基于HSSTHP高速接口,提供2套工程源码和技术支持
  • 国产紫光同创FPGA实现SDI视频编解码,基于HSSTHP高速接口,提供3套工程源码和技术支持
  • 【Python】Selenium切换网页的标签页的写法(全!!!)
  • 重庆动物园大熊猫被游客扔玻璃瓶,相同地方曾被扔可乐瓶
  • 央行:今日起下调再贷款利率0.25个百分点
  • 巴基斯坦军方:印度导弹袭击已造成至少3死14伤
  • 欧盟官员:欧盟酝酿对美关税政策反制措施,包含所有选项
  • 无人机穿越大理崇圣寺千年古塔时“炸机”,当地:肇事者已找到,将被追责
  • 广东省联社:积极推动改制组建农商联合银行工作