Java开发中,正常状况下,在执行了try代码块以后,finally中的代码必定会执行。咱们实际开发也常常会利用这个特性,在finally中来执行一些特殊的操做,好比:释放资源、释放锁等。java
demo线程
public class Finally { public static void main(String[] args) { try { //正常业务逻辑 System.out.println("I am try"); throw new RuntimeException("I am RuntimeExecption"); } catch (Exception e) { //异常处理 System.out.println("I am Exception -> " + e.getMessage()); } finally { //释放资源等 System.out.println("I am Finally"); } } }
executecode
I am try I am Exception -> I am RuntimeExecption I am Finally
那么是否是finally中的代码必定会被执行呢?资源
其实否则,目前做者了解到有两种状况下,finally中的代码不会被执行(不考虑try以前出现异常或者return的状况,换言之,在try以前出现异常或者return时,try对应的finally中的内容不会被执行)开发
demoget
public class Finally { public static void main(String[] args) { try { //正常业务逻辑 System.out.println("I am try"); throw new RuntimeException("I am RuntimeExecption"); } catch (Exception e) { //异常处理 System.out.println("I am Exception -> " + e.getMessage()); System.exit(1);//异常关闭虚拟机 } finally { //释放资源等 System.out.println("I am Finally"); } } }
execute虚拟机
I am try I am Exception -> I am RuntimeExecption
上面的代码在出现了异常以后,使用System.exit(1)退出关闭虚拟机,finally中的代码固然没法执行。it
demoio
public class Finally { public static void main(String[] args) throws Exception { Thread thread = new Thread(new Runnable() { public void run() { try { //正常业务逻辑 System.out.println("I am try"); Thread.sleep(1000); } catch (Exception e) { //异常处理 System.out.println("I am Exception -> " + e.getMessage()); } finally { //释放资源等 System.out.println("I am Finally"); } } }); thread.setDaemon(true); thread.start(); Thread.sleep(1000); System.out.println("end"); } }
executeclass
I am try end
使用setDaemon(true)方法来设置线程为守护线程,从打印结果中能够看到,守护线程中,try代码块中的代码执行了,finally代码块未必执行。主要缘由是由于守护线程会随着全部非守护线程的退出而退出。上述在主线程和守护线程中都设置sleep(1000)的缘由是怕线程run()方法还未开始执行主线程就退出了,这样的话try代码块中的内容都不会执行。固然不是说守护线程中的finally代码必定不会执行。
java中,若是想要执行try中的代码以后,不容许再执行finally中的代码,有如下两种方式: