Java多线程之捕获子线程中的异常---面试经

在某些场景下,我们经常需要使用多线程来执行任务提高性能,但是我们知道正常的主线程是无法处理子线程的异常的,一旦出现异常就会传播到控制台。这个时候我们需要在线程里面处理异常怎么办呢,我们可以使用Executor来处理。

在Java5中新加入了一个Thread.UncaughtExceptionHandler接口,这个接口可以让我们在每个Thread对象上都附着一个异常处理器,它的unacughtException()方法线程因未捕获的异常而死亡时被调用。

首先我们我们先实现Thread.UncaughtExceptionHandler接口:

 

class myUncaughtExceptionhandler implements Thread.UncaughtExceptionHandler{//实现线程异常处理接口

    @Override
    public void uncaughtException(Thread t, Throwable e) {
        System.out.println("cause"+ e);
    }
}

我们在自定义一个线程工厂:

class HandlerThreadFactory implements ThreadFactory{
    @Override
    public Thread newThread(Runnable r) {
        System.out.println(this+"create new thread");
        Thread t = new Thread(r);
        System.out.println("create"+t);
        t.setUncaughtExceptionHandler(new myUncaughtExceptionhandler());//设置我们自定义的异常处理
        //Thread.setDefaultUncaughtExceptionHandler();也可使用此方法设置默认的处理器
        System.out.println("eh="+t.getUncaughtExceptionHandler());
        return t;
    }
}

最后我们实现一个Runnable接口,并在run方法中抛出一个异常:

class MyThread implements Runnable {
    @Override
    public void run() {
        Thread t = Thread.currentThread();
        System.out.println("run()"+ t);
        System.out.println("eh="+t.getUncaughtExceptionHandler());
        throw new RuntimeException();
    }
}

ok,我们再写个main方法来测试一些:

public static void main(String[] args){
    ExecutorService exe = Executors.newCachedThreadPool(new HandlerThreadFactory());//使用我们自定义的ThreadFactory
    exe.execute(new MyThread());
}

运行结果如下图所示:

 

concurrence.HandlerThreadFactory@14ae5a5create new thread
createThread[Thread-0,5,main]
eh=concurrence.myUncaughtExceptionhandler@7f31245a
run()Thread[Thread-0,5,main]
eh=concurrence.myUncaughtExceptionhandler@7f31245a
concurrence.HandlerThreadFactory@14ae5a5create new thread
createThread[Thread-1,5,main]
eh=concurrence.myUncaughtExceptionhandler@154d7c22
causejava.lang.RuntimeException

很明显,程序可以运行,说明异常被捕获了,并且也是我们所抛出的异常,希望对大家有所帮助。

 

消化于:https://blog.csdn.net/MaybeUnforgiven/article/details/72989497

posted @ 2018-04-02 22:41  Ankermaker  阅读(816)  评论(0编辑  收藏  举报