Java中try-finally块的执行顺序

本文主要介绍的关于异常处理的时候try-catch-finally块的执行顺序,一般情况下,finally块是会执行,在Java中,try-finally块的执行顺序通常遵循以下规则:

  1. try块中的代码首先被执行。
  2. 如果try块中的代码执行完毕,控制流将转到finally块。无论try块中的代码是否抛出异常,finally块中的代码都将被执行。
  3. finally块中的代码执行完毕后,整个try-finally块结束,控制流将继续到下一个语句或代码块。

但是有几种情况是不执行的,比如:

arduino 复制代码
    1). return语句在try之前,还没执行就返回了,当然不执行。 

    2). try语句中用了system.exit(0)强制退出JVM,暴力退出当然也不会执行。

其次为什么要介绍这一部分,首先重要的一点是,在很多面试题目中,会出现这样的题目,其次,理解掌握try-catch-finally块也有助于我们对异常处理的理解。

首先来看一段简单的代码(某公司的面试题)

javascript 复制代码
public class TestFinally2 {

	static String s="";
	public static void main(String[] args) {
		s=test();
		System.out.println("最终结果:"+s);
		
	}
	private static String test() {
		// TODO Auto-generated method stub
	
		try {
			s="a";
			System.out.println("try!");
			return s;//放入栈中,没有直接返回
		} finally {
			System.out.println("come finnal...");
			s="b";
			System.out.println("s:"+s);
		
		}
	}
}

运行结果:看到运行结果是不是很惊讶呢,最终结果为什么不是b呢

原因:try-finally块中try有return语句,但是执行完毕之后没有立即返回,因为要执行finally块,try中的return结果会放在类似一个队列中,之后如果finally中有return语句,则会把finally中的return语句中的结果放入队列中,最终的是队列中的第一个数据,即finally中return的结果。如果finally中没有return语句,不管怎么改变变量,返回结果还是try块改变的值。比如上面那道题,在try块中s为a,在finally中s为b,但是finally没有return,所以最终结果就是a。

总结:

  1. finally语句在try和catch语句中的return执行后、返回前执行;
  2. 若finally语句中没有return,则其执行结果不影响try和catch中已确定的返回值;
  3. 若finally语句中有return,则其执行后的结果会直接返回

根据了上面的结论和理解,我们在看一道题:

javascript 复制代码
public class TestFinally {

	public static void main(String[] args) {
		System.out.println(new TestFinally().test());
	}
	
	int test(){
		try{
			return func1();
			
		}
		finally{
			return func2();
		}
	}
	
	int func1(){
		System.out.println("func1");
		return 1;
	}
	int func2(){
		System.out.println("func2");
		return 2;
	}
}

运行结果:

想必根据我的结论应该可以容易得出吧!try块与finally块中都有return,所以最终返回结果就是finally中的return结果。

相关推荐
追逐时光者38 分钟前
Everything替代工具,一款基于 .NET 开源免费、高效且用户友好文件搜索工具!
后端·.net
QX_hao1 小时前
【Go】--数据类型
开发语言·后端·golang
桦说编程1 小时前
线程池拒绝策略避坑:谨慎使用抛弃策略,可能导致系统卡死
java·后端
BingoGo1 小时前
PHP 15 个高效开发的小技巧
后端·php
锥栗1 小时前
【Redis】【缓存】理解缓存三大问题:缓存穿透、缓存击穿与缓存雪崩及解决方案
java·后端·面试
9号达人1 小时前
泛型+函数式:让策略模式不再是复制粘贴地狱
java·后端·面试
柑木2 小时前
开发必备-使用DevContainer技术消除 “在我这能运行”
后端
武子康2 小时前
大数据-122 - Flink Watermark 全面解析:事件时间窗口、乱序处理与迟到数据完整指南
大数据·后端·flink
她说彩礼65万2 小时前
Asp.net core Kestrel服务器详解
服务器·后端·asp.net
2 小时前
JUC专题-线程安全性之可见性有序性
后端