Callable


 

 

package test.com.hisi.d;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;

public class DTest {

    public static void main(String[] args) {
        int timeout = 2;
        ExecutorService executor = Executors.newSingleThreadExecutor();
        Boolean result = false;
        Future<Boolean> future = executor.submit(new TaskThread("發送請求"));//將任務提交給線程池
        try {
            System.out.println("begin:");
            result = future.get(timeout, TimeUnit.SECONDS);   //1
            //result = future.get(timeout, TimeUnit.MILLISECONDS); //2
            System.out.println("發送請求任務的返回結果: " + result);  
        } catch (InterruptedException e) {
            System.out.println("線程中斷出錯。");
            future.cancel(true);// 中斷執行此任務的線程
        } catch (ExecutionException e) {
            System.out.println("線程服務出錯。");
            future.cancel(true);
        } catch (TimeoutException e) {// 超時異常
            System.out.println("超時。");
            future.cancel(true);
        } finally {
            System.out.println("線程服務關閉。");
            executor.shutdown();
        }
    }

    static class TaskThread implements Callable<Boolean> {
        private String task;

        public TaskThread(String temp) {
            this.task = temp;
        }

        public Boolean call() {
            //for用於模擬超時
            for (int i = 0; i < 999999999; i++) {
                if (i == 999999998) {
                    System.out.println(task + " 成功!");
                }
                if (Thread.interrupted()) {
System.out.println("---interrupted----"); return false; } } System.out.println("繼續執行.........."); return true; } } }

begin:
發送請求 成功!
繼續執行..........
發送請求任務的返回結果: true
線程服務關閉。

--------------------------------------

若使用result = future.get(timeout, TimeUnit.MILLISECONDS);則結果為

begin:
超時。
---interrupted----
線程服務關閉。

package test.com.hisi.d;

import java.util.concurrent.Callable;

class MyCallable implements Callable<Object> {
    private int flag;

    public MyCallable(int flag) {
        this.flag = flag;
    }

    public String call() throws Exception {
        if (this.flag == 0) {
            return "flag = 0";
        }

        if (this.flag == 1) {
            try {
                while (true) {
                    System.out.println("looping.");
                    Thread.sleep(2000);
                }
            } catch (InterruptedException e) {
                System.out.println("Interrupted");
            }

            return "false";
        } else {
            throw new Exception("Bad flag value!");
        }
    }
}

 

package test.com.hisi.d;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class FutureGetBlock {

    public static void main(String[] args) {
        // 定義3個Callable類型的任務
        MyCallable task1 = new MyCallable(0);
        MyCallable task2 = new MyCallable(1);
        MyCallable task3 = new MyCallable(2);
        // 創建一個執行任務的服務
        ExecutorService es = Executors.newFixedThreadPool(3);

        try {
            // 提交並執行任務,任務啟動時返回了一個Future對象,
            // 如果想得到任務執行的結果或者是異常可對這個Future對象進行操作
            Future<?> future1 = es.submit(task1);
            // 獲得第一個任務的結果,如果調用get方法,當前線程會等待任務執行完畢后才往下執行
            System.out.println("task1: " + future1.get());
            Future<?> future2 = es.submit(task2);
            // 等待5秒后,再停止第二個任務。因為第二個任務進行的是無限循環
            Thread.sleep(5000);
            System.out.println("task2 cancel: " + future2.cancel(true));
            // 獲取第三個任務的輸出,因為執行第三個任務會引起異常
            // 所以下面的語句將引起異常的拋出
            Future<?> future3 = es.submit(task3);
            System.out.println("task3: " + future3.get());
        } catch (Exception e) {
            System.out.println(e.toString());
        }

        // 停止任務執行服務
        es.shutdownNow();
    }
}

task1: flag = 0
looping.
looping.
looping.
Interrupted
task2 cancel: true
java.util.concurrent.ExecutionException: java.lang.Exception: Bad flag value!

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM