今天遇到一个问题,记录一下。
问题描述:
前置通知方法中使用了线程池ThreadPoolExecutor,线程中调用了方法A,在A方法中人为增加了一个除数为0的异常,且没有捕获异常,这时候发现我的切入点方法(即业务代码方法)中代码竟然执行了。
分析原因:
难道前置通知中有异常,业务代码会执行吗?
首先,我在前置通知方法中增加一个异常,来测试业务代码是否执行,发现业务代码没有执行,说明前置通知中异常且未捕获,会影响业务代码的;
那么为什么我的业务代码会执行呢?
然后,我把线程池去掉,把线程池内代码拿出来,在前置通知中直接调用方法A,这时候业务代码没有执行。
从这个测试结果可以推断出,是线程池ThreadPoolExecutor影响的,可能是线程池里捕获了异常。后来查看了线程池ThreadPoolExecutor的相关代码,发现我创建的线程池设置了线程异常处理器handler(RejectedExecutionHandler
),这个handler会捕获线程池内异常。如果不设置handler,线程池也会使用默认的handler,同样也会捕获异常。
另外一个关于AOP的讨论:前置通知方法和切入点方法是在同一个线程吗?
我的答案是同一个线程,因为我在前置通知和切入点方法中都打印了线程名字,发现是一样的。
但是网上也有说不是同一个线程的,具体原因没说,各位如果认为不是同一个线程的,希望留言说下原因。多谢!!!