初始化线程的4种方式

初始化线程的4种方式

一、继承Thread接口

    /**
     * 继承Thread接口
     */
    public static class Thread01 extends Thread{

        @Override
        public void run() {
            System.out.println("当前线程" + Thread.currentThread().getId()); // 当前线程11
            int i = 10/2;
            System.out.println("运行结果 : "+i);  // 运行结果 : 5
        }
    }
    
   // 测试
   public static void main(String[] args) {
        System.out.println("main 线程 : "+Thread.currentThread().getId());  // main 线程 : 1
        Thread01 thread01 = new Thread01();
        thread01.start(); //启动线程
    }

二、实现Runnable接口

 /**
     * 实现Runnable接口
     */
    public static class Runnable01 implements Runnable{

        @Override
        public void run() {
            System.out.println("当前线程" + Thread.currentThread().getId()); // 当前线程11
            int i = 10/2;
            System.out.println("运行结果 : "+i);  // 运行结果 : 5
        }
    }
    
    //测试
    public static void main(String[] args) {
        Runnable01 runnable01 = new Runnable01();
        Thread thread = new Thread(runnable01);
        thread.start();
     }

三、实现 Callable接口,FutureTask可以拿到返回结果

FutureTask可以拿到返回结果,可以处理异常

futureTask.get()阻塞等待整个线程执行完成,获取返回结果

  /**
     *  实现Callable接口
     */
    public static class Callable01 implements Callable<Integer>{

        @Override
        public Integer call() throws Exception {
            System.out.println("当前线程" + Thread.currentThread().getId()); // 当前线程11
            int i = 10/2;
            System.out.println("运行结果 : "+i);  // 运行结果 : 5
            Thread.sleep(5000);
            return i;
        }
    }
    
// 测试
 public static void main(String[] args) throws ExecutionException, InterruptedException {

        Callable01 callable01 = new Callable01();
        FutureTask<Integer> futureTask = new FutureTask<>(callable01);

        Thread thread = new Thread(futureTask);
        thread.start(); //启动线程
        Integer integer = futureTask.get();  //获取返回结果
        System.out.println(integer);   // 5
    }

四、线程池【ExecutorService】

线程池直接提交任务

我们的业务代码中,以上三种启动线程的方式都不用。避免启动线程消耗太多的资源,节约资源给更核心的业务。将所有的多线程异步任务都交给线程池执行

 public static void main(String[] args) throws ExecutionException, InterruptedException {
        ExecutorService executorService = Executors.newFixedThreadPool(10);
        executorService.execute(new Runnable01());
    }
    
 /**
     * 实现Runnable接口
     */
    public static class Runnable01 implements Runnable{

        @Override
        public void run() {
            System.out.println("当前线程" + Thread.currentThread().getId()); // 当前线程11
            int i = 10/2;
            System.out.println("运行结果 : "+i);  // 运行结果 : 5
        }
    }

总结

  1. 1,2不能得到返回值,3可以获取返回值
  2. 1,2,3都不能控制资源
  3. 4可以控制资源,性能稳定。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值