FutureTask取消线程池ThreadPoolExecutor 的任务执行

 FutureTask取消线程池ThreadPoolExecutor 的任务执行

 

package com.pool;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

public class MyThreadPool {

	private Map<String, FutureTask<String>> tasks = new HashMap<String, FutureTask<String>>();
	// 构造一个线程
	private ThreadPoolExecutor executor = new ThreadPoolExecutor(1, 1, 0L,
			TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>());

	/**
	 * @param tasksList
	 */
	public void addTaskList(List<Callable<String>> tasksList) {
		for (Callable<String> t : tasksList) {
			FutureTask<String> futureTask = new FutureTask<String>(t);
			executor.execute(futureTask);

			String key = Long.toHexString(System.nanoTime());
			tasks.put(key, futureTask);
		}
	}

	/**
	 * @param task
	 * @return
	 */
	public String addTask(Callable<String> task) {
		FutureTask<String> futureTask = new FutureTask<String>(task);
		executor.execute(futureTask);

		String key = Long.toHexString(System.nanoTime());
		tasks.put(key, futureTask);
		return key;
	}

	/**
	 * @param task
	 * @return
	 */
	public String addTask(Runnable task) {
		FutureTask<String> futureTask = new FutureTask<String>(task, null);
		executor.execute(futureTask);

		String key = Long.toHexString(System.nanoTime());
		tasks.put(key, futureTask);
		return key;
	}

	/**
	 * @param task
	 * @return
	 */
	public String addDBTask(Callable<String> task) {
		FutureTask<String> futureTask = new FutureTask<String>(task) {
			public boolean cancel(boolean mayInterruptIfRunning) {
				System.out.println("Roll Back and Closs Session");
				return super.cancel(mayInterruptIfRunning);
			}
		};
		executor.execute(futureTask);

		String key = Long.toHexString(System.nanoTime());
		tasks.put(key, futureTask);
		return key;
	}

	/**
	 * @param key
	 * @return
	 */
	public boolean taskIsDone(String key) {
		FutureTask<String> futureTask = tasks.get(key);
		if (futureTask != null) {
			return futureTask.isDone();
		}
		return false;
	}

	/**
	 * @param key
	 * @return
	 */
	public boolean taskIsCancelled(String key) {
		FutureTask<String> futureTask = tasks.get(key);
		if (futureTask != null) {
			return futureTask.isCancelled();
		}
		return false;
	}

	/**
	 * @param key
	 * @return
	 */
	public String getTaskResult(String key) {
		FutureTask<String> futureTask = tasks.get(key);

		if (futureTask.isDone()) {
			try {
				String result = futureTask.get();
				tasks.remove(key);
				return result;
			} catch (InterruptedException e) {
				e.printStackTrace();
				return null;
			} catch (ExecutionException e) {
				e.printStackTrace();
				return null;
			}
		} else {
			return null;
		}
	}

	/**
	 * @param task
	 * @return
	 */
	public String addTaskAndWaitResult(Callable<String> task) {
		FutureTask<String> futureTask = new FutureTask<String>(task);
		executor.execute(futureTask);

		String key = Long.toHexString(System.nanoTime());
		tasks.put(key, futureTask);
		try {
			return futureTask.get();
		} catch (InterruptedException e) {
			e.printStackTrace();
			return null;
		} catch (ExecutionException e) {
			e.printStackTrace();
			return null;
		}
	}

	/**
     * 
     */
	public void removeAllTask() {
		for (String key : tasks.keySet()) {
			executor.remove((Runnable) tasks.get(key));
			tasks.remove(key);
		}
	}

	/**
	 * @param key
	 */
	public void removeQueryTask(String key) {
		executor.remove((Runnable) tasks.get(key));
	}

	/**
	 * @param key
	 */
	public void removeTask(String key) {
		tasks.remove(key);
	}

	/**
     * 
     */
	public void clearTaskList() {
		tasks.clear();
	}

	public synchronized void stop() {
		try {
			executor.shutdownNow();
			executor.awaitTermination(1L, TimeUnit.MILLISECONDS);
		} catch (InterruptedException e) {
			e.printStackTrace();
		} finally {
			executor = null;
			tasks.clear();
			tasks = null;
		}
	}

	/**
	 * @param key
	 */
	public void cancelTask(String key) {

		FutureTask<String> futureTask = tasks.get(key);
		if (futureTask != null) {
			if (!futureTask.isDone()) {
				futureTask.cancel(true);
			}
		}
	}

	public void purgeCancelTask() {
		executor.purge();
		executor.getQueue();
	}

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		MyThreadPool exec = new MyThreadPool();

		ArrayList<String> keyList = new ArrayList<String>();
		ArrayList<String> removeKeyList = new ArrayList<String>();
		ArrayList<String> cancelKeyList = new ArrayList<String>();

		for (int i = 0; i < 15; i++) {

			// 产生一个任务,并将其加入到线程池
			String task = "task@ " + (i + 1);
			System.out.println("put " + task);

			final int a = i;
			keyList.add(exec.addTask(new Runnable() {
				@Override
				public void run() {
					System.err.println("第          " + a + "  线程     执行   111");
					try {
						Thread.sleep(500);
					} catch (Exception e) {
						e.printStackTrace();
					}
					System.err.println("第          " + a + "  线程     执行  222");
				}
			}));
		}
		
		try {
			Thread.sleep(3000);
		} catch (Exception e) {
			e.printStackTrace();
		}
		
		for (int i = 0; i < keyList.size(); i++) {
			exec.cancelTask(keyList.get(i));
		}
		
//		try {
//			Thread.sleep(1L);
//		} catch (InterruptedException e) {
//			e.printStackTrace();
//		}
//		for (int i = 0; i < keyList.size(); i++) {
//			if (exec.taskIsDone(keyList.get(i))) {
//				System.out.println(exec.getTaskResult(keyList.get(i)));
//				exec.removeTask(keyList.get(i));
//
//				removeKeyList.add(keyList.get(i));
//			} else {
//				exec.cancelTask(keyList.get(i));
//				System.out.println("Cancel task: " + (i + 1));
//				exec.removeTask(keyList.get(i));
//
//				cancelKeyList.add(keyList.get(i));
//			}
//		}
//		exec.purgeCancelTask();
//
//		exec.stop();
//		try {
//			Thread.sleep(6000L);
//		} catch (InterruptedException e) {
//			e.printStackTrace();
//		}
//		for (String key : cancelKeyList) {
//			if (exec.taskIsCancelled(key)) {
//				System.out.println("Cancel: " + key);
//			}
//		}
//		for (int i = 0; i < 10; i++) {
//			keyList.get(i);
//		}
	}

}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值