多线程实现的方式3:(开启不同的线程,分别进行求和)

41 篇文章 0 订阅

多线程实现的方式3:实现Callable接口(开启不同的线程,分别进行求和)

import java.util.concurrent.Callable;

 

/*

 * 线程求和案例

 */

public classMyCallable implementsCallable<Integer> {

 

   private int number;

 

   public MyCallable(int number) {

      this.number = number;

   }

 

   @Override

   public Integer call()throws Exception {

      int sum = 0;

      for (int x = 1; x <=number; x++) {

         sum+= x;

      }

      return sum;

   }

 

}

 

import java.util.concurrent.ExecutionException;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.Future;

 

/*

 * 多线程实现的方式3

 *     A:创建一个线程池对象,控制要创建几个线程对象。

 *        publicstatic ExecutorService newFixedThreadPool(int nThreads)

 *    B:这种线程池的线程可以执行:

 *        可以执行Runnable对象或者Callable对象代表的线程

 *        做一个类实现Runnable接口。

 *    C:调用如下方法即可

 *        Future<?>submit(Runnable task)

 *       <T>Future<T> submit(Callable<T> task)

 *    D:我就要结束,可以吗?

 *       可以。

 */

public classCallableDemo {

   public static void main(String[] args)throws InterruptedException,ExecutionException {

      // 创建线程池对象

      ExecutorServicepool = Executors.newFixedThreadPool(2);

 

      // 可以执行Runnable对象或者Callable对象代表的线程

      Future<Integer>f1 = pool.submit(newMyCallable(100));

      Future<Integer>f2 = pool.submit(newMyCallable(200));

 

      // V get()

      Integeri1 = f1.get();

      Integeri2 = f2.get();

 

      System.out.println(i1);

      System.out.println(i2);

 

      // 结束

      pool.shutdown();

   }

}

运行结果:

5050

20100

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值