利用FutureTask进行线程并发操作

package graph;


import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;


public class FutureTaskDemo {
 
       // 创建一个执行任务的服务  
      static ExecutorService executorTask = Executors.newFixedThreadPool(3);
      static ExecutorService executorTask1 = Executors.newFixedThreadPool(3);
     
   public static void main(String[] args) { 

    long begin  = System.currentTimeMillis();


    for(int i = 0;i<100000;i++){
       Callable<String> task = new Callable<String>() {  
           public String call() {  
               System.out.println("SaveOperation");  
               return "success"; 
           }  
       };  
         
       Callable<String> task1 = new Callable<String>() {  
           public String call() {  
               System.out.println("SelectOperation");  
               return "failure"; 
           }  
       };  
      
       FutureTask<String> ft2 = new FutureTask<String>(task);  
       FutureTask<String> ft3 = new FutureTask<String>(task1);  
       try {  
           executorTask.submit(ft2);    
           executorTask1.submit(ft3);  

          executorTask.get();

           executorTask1.get();

       } catch (Exception e) {  
       }
      }  
    try {      
            if(executorTask.isShutdown() == false){
            executorTask.shutdown();
            }
            if(executorTask1.isShutdown() == false){
            executorTask1.shutdown();
            }
} catch (Exception e) {

e.printStackTrace();
}
   long end = System.currentTimeMillis();
   System.out.println(end - begin);
   }
   
}  
  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FutureTask是一个非常强大的多线程工具,可以用来实现异步任务和并发控制等功能。结合FutureTask可以实现多线程。 下面是一个简单的例子,演示如何使用FutureTask实现多线程: ```java import java.util.concurrent.*; public class FutureTaskDemo { public static void main(String[] args) throws Exception { // 创建一个Callable对象 Callable<String> callable = new Callable<String>() { public String call() throws Exception { // 模拟一个耗时的操作 Thread.sleep(5000); return "Hello World!"; } }; // 创建一个FutureTask对象 FutureTask<String> futureTask = new FutureTask<String>(callable); // 创建一个线程对象,并启动 Thread thread = new Thread(futureTask); thread.start(); // 主线程继续执行其他任务 System.out.println("主线程执行其他任务..."); // 等待异步任务完成,并获取结果 String result = futureTask.get(); System.out.println("异步任务的结果是:" + result); } } ``` 在这个例子中,我们首先创建了一个Callable对象,它会模拟一个耗时的操作,并返回一个字符串。然后我们创建了一个FutureTask对象,并将Callable对象传递给它作为参数。接着我们创建了一个线程对象,并启动它。主线程继续执行其他任务,然后等待异步任务完成,并获取结果。 在这个例子中,我们使用了FutureTask的get方法,来等待异步任务完成,并获取结果。get方法会阻塞当前线程,直到异步任务完成并返回结果。如果异步任务抛出了异常,get方法会将异常重新抛出。如果不想阻塞当前线程,可以使用isDone方法来判断异步任务是否完成,或者使用get方法的重载方法,传递一个超时时间作为参数,来等待异步任务完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值