线程创建的4种方式
创始人
2024-11-11 09:09:04

线程创建的4种方式

  • 方式一:继承 Thread 类
  • 方式二:实现 Runnable 接口
  • 方式三:实现 Callable 接口
  • 方式四:使用线程池


💖The Begin💖点点关注,收藏不迷路💖

方式一:继承 Thread 类

原理:

通过继承java.lang.Thread类并覆盖其run方法,可以创建新的线程。当调用线程的start()方法时,会启动一个新的线程来执行run方法中的代码。

示例代码:

public class MyThread extends Thread {       @Override       public void run() {           System.out.println("线程运行中:" + Thread.currentThread().getName());       }          public static void main(String[] args) {           MyThread thread = new MyThread();           thread.start();       }   } 

优缺点:

优点:实现简单,易于理解。
缺点:Java不支持多重继承,如果当前类已经继承了其他类,则无法再继承Thread类。

方式二:实现 Runnable 接口

原理:

实现java.lang.Runnable接口,并将该实现类的实例传递给Thread类的构造器。这种方式与继承Thread类相比更加灵活,因为Java支持实现多个接口。

示例代码:

public class MyRunnable implements Runnable {       @Override       public void run() {           System.out.println("线程运行中:" + Thread.currentThread().getName());       }          public static void main(String[] args) {           Thread thread = new Thread(new MyRunnable());           thread.start();       }   } 

优缺点:

优点:灵活性高,支持实现多个接口,且易于与线程池等高级功能结合使用。
缺点:相对继承Thread类来说,代码稍显繁琐。

方式三:实现 Callable 接口

原理:

实现java.util.concurrent.Callable接口与实现Runnable接口类似,但Callable可以返回一个结果,并且可以抛出异常。Callable通常与FutureTask一起使用,FutureTask包装了Callable或Runnable对象,提供了更为强大的功能,比如可以检查计算是否完成,等待计算完成,并检索计算结果。

示例代码:

import java.util.concurrent.Callable;   import java.util.concurrent.ExecutionException;   import java.util.concurrent.FutureTask;      public class MyCallable implements Callable {       @Override       public Integer call() throws Exception {           return 123;       }          public static void main(String[] args) throws ExecutionException, InterruptedException {           FutureTask futureTask = new FutureTask<>(new MyCallable());           Thread thread = new Thread(futureTask);           thread.start();              // 等待计算完成并获取结果           System.out.println("计算结果是:" + futureTask.get());       }   } 

优缺点:

优点:支持返回结果和抛出异常,功能更强大。
缺点:相比Runnable,实现稍显复杂,且通常与FutureTask一起使用,增加了代码的复杂性。

方式四:使用线程池

原理:

线程池是管理一组工作线程的资源池,用于执行异步任务。使用线程池可以减少线程创建和销毁的开销,提高系统的响应速度和吞吐量。Java提供了Executors工厂类来创建不同类型的线程池。

示例代码:

import java.util.concurrent.ExecutorService;   import java.util.concurrent.Executors;      public class ThreadPoolExample {       public static void main(String[] args) {           // 创建一个固定大小的线程池           ExecutorService executor = Executors.newFixedThreadPool(5);              for (int i = 0; i < 10; i++) {               int taskId = i;               executor.submit(() -> {                   System.out.println("线程运行中,任务ID:" + taskId);               });           }              // 关闭线程池(不再接受新任务,但已提交的任务会继续执行)           executor.shutdown();       }   } 

优缺点:

优点:减少线程创建和销毁的开销,提高资源利用率,易于管理和监控线程。
缺点:需要合理配置线程池。
在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖

相关内容

热门资讯

裸辞做“一人公司”,我后悔了 去年这个时候,一位以色列程序员正在东南亚旅行。他顺手把一个在脑子里转了很久的想法做成了产品,一个让任...
南京建成国内首个Pre-6G试... 4月21日,2026全球6G技术与产业生态大会在南京开幕。全息互动技术展台前,一名远在北京的工作人员...
超梵求职受邀参加“2025抖音... 超梵求职受邀参加“2025抖音巨量引擎成人教育行业生态大会”,探讨分享优质内容传播,服务万千学员。 ...
摩托罗拉Razr 2026(R... IT之家 4 月 22 日消息,摩托罗拉宣布新一代 Razr 折叠手机将于 4 月 29 日在美国发...
库克卸任,特纳斯领航:苹果新纪... 苹果首席执行官蒂姆·库克将卸任,硬件工程主管约翰·特纳斯将接任,苹果公司今天宣布此事。 库克将在夏季...