ThreadPoolExecutor异常处理_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > ThreadPoolExecutor异常处理

ThreadPoolExecutor异常处理

 2013/6/19 11:47:21  jamie.wang  程序员俱乐部  我要评论(0)
  • 摘要:java.util.concurrent包中的ThreadPoolExecutor,提供了java语言的线程池,你可以提交一个返回结果的任务(submit(Callable),返回Future),或者执行一个不返回结果的任务(execute(Runnable)),但提交的任务可能会抛异常,这就需要处理异常:1.对于submit的任务,框架会将异常保持在future里,并包装在ExecutionException里,当调用Future.get()时,再次throw
  • 标签:thread 异常处理 异常

java.util.concurrent包中的ThreadPoolExecutor,提供了java语言的线程池,你可以提交一个返回结果的任务(submit(Callable),返回Future),或者执行一个不返回结果的任务(execute(Runnable)),但提交的任务可能会抛异常,这就需要处理异常:

1. 对于submit的任务,框架会将异常保持在future里,并包装在ExecutionException里,当调用Future.get()时,再次throw,这时可以调用ExecutionException.getCause()获取包装的exception,这种情况下,设置UncaughtExceptionHandler也不会被调用。

2. 对应execute的任务,会直接throw,可以设置一个UncaughtExceptionHandler,例如:

class="java" name="code">import java.lang.Thread.UncaughtExceptionHandler;
import java.util.Random;
import java.util.concurrent.CancellationException;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Future;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;

public class ExecutorServiceDemo {

    public static void testExecute() {
        ExecutorService executors = new ThreadPoolExecutor(10, 20, 60, TimeUnit.SECONDS,
                new LinkedBlockingQueue<Runnable>(), new ThreadFactory() {
                    final AtomicInteger threadNumber = new AtomicInteger(1);

                    public Thread newThread(Runnable r) {
                        Thread t = new Thread(Thread.currentThread().getThreadGroup(), r, "topPatternTasklet-thread"
                                + (threadNumber.getAndIncrement()));
                        t.setUncaughtExceptionHandler(new UncaughtExceptionHandler() {

                            public void uncaughtException(Thread t, Throwable e) {
                                System.out.println(e);
                            }
                            
                        });
                        return t;
                    }
                }, new ThreadPoolExecutor.CallerRunsPolicy());

        final Random r = new Random();
        for (int i = 0; i < 10; ++i) {
            executors.execute(new Runnable() {

                public void run() {
                    try {
                        int ri = r.nextInt(1000);
                        Thread.sleep(ri);
                        if (ri % 3 == 0) {
                            System.out.println("ri:" + ri);
                            throw new RuntimeException("haha error!");
                        }
                        System.out.println(Thread.currentThread());
                    } catch (InterruptedException e) {
                    }
                }
            });
        }

        executors.shutdown();
        System.out.println("finished"); 
    }
    public static void main(String[] args) {
        testExecute();
    }
}

?

发表评论
用户名: 匿名