并发编程(二)Java中的多线程
文章更新时间:2021/09/06
一、创建多线程
创建多线程有以下几种方法:
- 继承Thread,重写run方法
- 实现Runnable接口,重写run方法【无返回值】
- 实现Callable接口,重写call方法【有返回值】
继承Thread
/** * 创建一个类,继承Thread,重写run方法 * @author 有梦想的肥宅 */ class MyThread extends Thread { @Override public void run() { for (int i = 0; i < 100; i++) { System.out.println(i); } } }
实现Runnable接口
/** * 实现Runnable接口,重写run方法 * @author 有梦想的肥宅 */ class MyRunnable implements Runnable { @Override public void run() { for (int x = 0; x < 100; x++) { System.out.println(x); } } }
实现Callable接口
/** * 实现Callable接口,重写call方法 * @author 有梦想的肥宅 */ class MyCallableThread implements Callable<Integer> { @Override public Integer call() throws Exception { int count = 0; for (int i = 0; i < 100; i++) { System.out.println(Thread.currentThread().getName() + " " + i); count += i; } return count; } }
通过 Callable 和 Future 创建线程的过程:
- 1. 创建 Callable 接口的实现类,并实现 call() 方法,该 call() 方法将作为线程执行体,并且有返回值。
- 2. 创建 Callable 实现类的实例,使用 FutureTask 类来包装 Callable 对象,该 FutureTask 对象封装了该 Callable 对象的 call() 方法的返回值。
- 3. 使用 FutureTask 对象作为 Thread 对象的 target 创建并启动新线程。
- 4. 调用 FutureTask 对象的 get() 方法来获得子线程执行结束后的返回值。
二、如何启动线程
/** * 测试启动线程 * * @author 有梦想的肥宅 * @date 2021/9/6 */ public class CreateThreadTest { public static void main(String[] args) { //1、继承Thread【MyThread】 new MyThread().start(); //2、实现Runnable接口【MyRunnable】 new Thread(new MyRunnable()).start(); //3、实现Callable接口【MyCallableThread】 FutureTask<Integer> futureTask = new FutureTask<>(new MyCallableThread()); new Thread(futureTask, "有返回值的线程:").start(); try { System.out.println("Future的返回值:" + futureTask.get()); } catch (Exception e) { e.printStackTrace(); } } }
三、使用多线程时需要注意的细节
run()和start()方法区别
- run() : 仅仅是封装被线程执行的代码,直接调用是普通方法。
- start() : 首先启动了线程,然后再由jvm去调用该线程的run()方法,执行线程时用这个方法。PS:内部调用jvm启动线程的方法start0()是native方法。
几种创建线程的方法哪种比较好
一般我们使用实现Runnable接口
- 可以避免java中的单继承的限制
- 应该将并发运行任务和运行机制解耦
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律