科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道用finally做什么

用finally做什么

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

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

作者:中国IT实验室 来源:中国IT实验室 2007年9月25日

关键字: 编程 java

  • 评论
  • 分享微博
  • 分享邮件

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

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章