java 中的finally你知多少_java中的finally用来做什么

在没有“垃圾收集”以及“自动调用破坏器”机制的一种语言中(注释⑤),finally显得特别重要,因为程序员可用它担保内存的正确释放——无论在try块内部发生了什么状况。但java提供了垃圾收集机制,所以内存的释放几乎绝对不会成为问题。另外,它也没有构建器可供调用。既然如此,Java里何时才会用到finally呢?

3cf4180f8bade0908234413a7d454481.png

⑤:“破坏器”(Destructor)是“构建器”(Constructor)的反义词。它代表一个特殊的函数,一旦某个对象失去用处,通常就会调用它。我们肯定知道在哪里以及何时调用破坏器。C++提供了自动的破坏器调用机制,但Delphi的Object Pascal版本1及2却不具备这一能力(在这种语言中,破坏器的含义与用法都发生了变化)。

除将内存设回原始状态以外,若要设置另一些东西,finally就是必需的。例如,我们有时需要打开一个文件或者建立一个网络连接,或者在屏幕上画一些东西,甚至设置外部世界的一个开关,等等。如下例所示:

//: OnOffSwitch.java

// Why use finally?

class Switch {

boolean state = false;

boolean read() { return state; }

void on() { state = true; }

void off() { state = false; }

}

public class OnOffSwitch {

static Switch sw = new Switch();

public static void main(String[] args) {

try {

sw.on();

// Code that can throw exceptions...

sw.off();

} catch(NullPointerException e) {

System.out.println("NullPointerException");

sw.off();

} catch(IllegalArgumentException e) {

System.out.println("IOException");

sw.off();

}

}

} ///:~

这里的目标是保证main()完成时开关处于关闭状态,所以将sw.off()置于try块以及每个违例控制器的末尾。但产生的一个违例有可能不是在这里捕获的,这便会错过sw.off()。然而,利用finally,我们可以将来自try块的关闭代码只置于一个地方:

//: WithFinally.java

// Finally Guarantees cleanup

class Switch2 {

boolean state = false;

boolean read() { return state; }

void on() { state = true; }

void off() { state = false; }

}

public class WithFinally {

static Switch2 sw = new Switch2();

public static void main(String[] args) {

try {

sw.on();

// Code that can throw exceptions...

} catch(NullPointerException e) {

System.out.println("NullPointerException");

} catch(IllegalArgumentException e) {

System.out.println("IOException");

} finally {

sw.off();

}

}

} ///:~

在这儿,sw.off()已移至一个地方。无论发生什么事情,都肯定会运行它。

即使违例不在当前的catch从句集里捕获,finally都会在违例控制机制转到更高级别搜索一个控制器之前得以执行。如下所示:

//: AlwaysFinally.java

// Finally is always executed

class Ex extends Exception {}

public class AlwaysFinally {

public static void main(String[] args) {

System.out.println(

"Entering first try block");

try {

System.out.println(

"Entering second try block");

try {

throw new Ex();

} finally {

System.out.println(

"finally in 2nd try block");

}

} catch(Ex e) {

System.out.println(

"Caught Ex in first try block");

} finally {

System.out.println(

"finally in 1st try block");

}

}

} ///:~

该程序的输出展示了具体发生的事情:

Entering first try block

Entering second try block

finally in 2nd try block

Caught Ex in first try block

finally in 1st try block

若调用了break和continue语句,finally语句也会得以执行。请注意,与作上标签的break和continue一道,finally排除了Java对goto跳转语句的需求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值