finally语句块与return的执行关系

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

这是一道Java面试题:try{ }里有一个return语句,那么紧跟在这个try后的finally{}里的code会不会被执行,什么时候被执行,在return前还是后?(如果try后面有个catch块,里面有return语句,那么finally语句会不会执行?)

finally语句块的作用就是为了保证无论出现什么情况,一定要执行的,那么finally里的code 肯定会执行,并且是在return前执行。(只要语句执行了,肯定是在return前执行的。finally 中也可以有return,并且会覆盖其他的return)

根据java规范:在try-catch-finally中,如果try-finally或者catch-finally 中都有return,则两个return语句都执行并且最终返回到调用者那里的是finally中return的值;而如果finally中没有return,则理所当然的返回的是try或者catch中return的值,但是finally中的代码是必须要执行的,方法在return的时候并不是把它所拥有的那个值给返回了,而是复制一份返回!因此,对于基本类型的数据,在finally中改变return的值对返回值没有任何影响,而对于引用类型的数据,就有影响。(JAVA中基本类型变量存储在___中,引用类型的对象存储在____中,对象的引用地址存储在____中。

A. 堆

B. 栈

C. 寄存器

D. 静态存储区

BBA

基本类型和对象的引用都放在栈中,new出的对象和数组放在堆中

public class FinallyTest

{

public static void main(String[] args) {

System.out.println("x的值是"+new FinallyTest().test());;

}

@SuppressWarnings("finally")

static int test()

{

int x = 1;

try

{

//x++;

return x;

}

finally

{

++x;

System.out.println("x的值当前值是" +x);

//return x;

}

}

}

执行结果:x的值当前值是2

x的值是1

若finally中包含return语句

public class FinallyTest

{

public static void main(String[] args) {

System.out.println("x的值是"+new FinallyTest().test());;

}

@SuppressWarnings("finally")

static int test()

{

int x = 1;

try

{

//x++;

return x;

}

finally

{

++x;

System.out.println("x的值当前值是" +x);

return x;

}

}

}

执行结果是:x的值当前值是2

x的值是2

若引用类型的数据,就有影响,

public class FinallyTest4 {

public static void main(String[] args) {

System.out.print("k的最终返回值是: "+tt());

}

public static StringBuffer tt() {

StringBuffer k = new StringBuffer();

try {

k.append(2);

return k;

} catch(Exception e){

k.append(3);

return k;

} finally {

k.append(5);

}

}

}

执行结果是:的最终返回值是: 25

补充:java存储数据的地方以及java九种基本类型

2009-12-14 10:09

程序运行时6个不同地方可以存储数据:

1、寄存器(register):这是最快的存储区——处理器内部。但是寄存器数量及其有限,所以寄存器由编

译器根据需求进行分配,你不能直接控制,也不能在程序中感觉到寄存器存在的任何迹象。

2、堆栈(stack):位于通用的RAM中,但通过它的“堆栈指针”可以从处理器哪里获得直接支持。堆栈指

针若向下移动,则分配新的内存;若向上移动,则释放那些内存。这是一种快速有效的分配存储方法,仅

次于寄存器。创建程序时,Java编译器必须知道存储在堆栈内所有数据的确切大小和生命周期。因为它必

须生产相应的代码,以便上下移动堆栈指针。这一约束限制了程序的灵活性,所以虽然某些Java数据存储

于堆栈中——特别是对象引用,但是Java对象并不存储于其中。

3、堆(heap):一种通用性的内存池(也在RAM区),用于存放所有的Java 对象。堆不同于堆栈的好处是

:编译器不需要知道要从堆里分配多少存储区域,也不必知道存储的数据在堆里存活多长时间。因此,在

队里分配存储有很大的灵活性。当需要创建一个对象时,只需要new下。执行这行代码时,会自动在堆里进

行存储分配。当然,为这种灵活性必须付出相应的代价。用堆进行存储分配比用堆栈进行存储需要更多的

相关文档
最新文档