从函数调用栈的角度看try catch finally有返回值时的执行顺序

来源:互联网 发布:java bug 工具 编辑:程序博客网 时间:2024/06/12 21:19

前几天在看c语言函数的调用过程时,突然对之前一些不理解的知识点豁然大悟,比如说java异常捕获的返回值问题。我们在百度上搜一下try-catch-finally-return的相关内容,大部分的说解都是罗列各种情况进行各种代码测试,然后在最后面来个总结,比如像下面这篇”最有说服力”的文章:
有return的情况下try catch finally的执行顺序(最有说服力的总结)
这些文章写的虽然全面,但是相信很多了会像我一样看了就忘,因为它们都只告诉了我们情况是这样的,而并没有告诉我们为什么这样,这样就导致了很多人就只能去死记硬背了。当我了解了函数调用栈的相关内容后,其中的一个知识点使我触类旁通,原来函数在执行return 变量的时候,其实是将变量的值保存到一个寄存器中,我们只要记住这一点,就可以知道到异常捕获返回的内容是什么了。还是看我开头给的那篇文章,它下面有一个测试程序,代码如下:

public class FinallyTest  {    public static void main(String[] args) {         System.out.println(new FinallyTest().test());;    }    static int test()    {        int x = 1;        try        {            x++;            return x;        }        finally        {            ++x;        }    }

大家想,根据我刚才说的那个知识点,函数的返回值应该是什么呢?首先我默认大家都知道finally语句是一定在并且一定要在try以及catch语句块后面执行的,然后看一下程序里的try语句块,当执行到retrun x的时候,x的值已经放到寄存器里面了,所以finally里的对x的修改对返回值已经没有影响了。但是如果finally里也有return的话,那么寄存器里的值同样也会被改变。所以结果是2。
那有人会问了,你刚刚说的是基本数据类型,那对象怎么办?首先我们要清楚,对象的引用其实就是一个指针,所以当函数在返回一个对象的时候,其实就是把对象的指针放到寄存器里,道理其实都是一样的,我们完全可以通过这个知识点举一反三。

原创粉丝点击