没有"捕获"的"尝试最终"是否有意义?

gla*_*den 119 java exception

我看到了一些这样的代码:

    try
    {
        db.store(mydata);
    }
    finally
    {
        db.cleanup();
    }
Run Code Online (Sandbox Code Playgroud)

我以为try应该有一个catch

为什么这段代码会这样做?

Tay*_*ese 171

如果您希望当前正在执行的方法仍然抛出异常,同时允许适当地清理资源,这将非常有用.下面是从调用方法处理异常的具体示例.

public void yourOtherMethod() {
    try {
        yourMethod();
    } catch (YourException ex) {
        // handle exception
    }
}    

public void yourMethod() throws YourException {
    try {
        db.store(mydata);
    } finally {
        db.cleanup();
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 常用的锁如:lock.lock(); 最后尝试{/*locked*/} {lock.unlock()} (13认同)
  • @barth当没有“catch”块时,“finally”中抛出的异常将在“try”块中的任何异常之前执行。因此,如果有两个异常,一个在“try”中,一个在“finally”中,则唯一抛出的异常就是“finally”中的异常。这种行为在 PHP 和 Python 中并不相同,因为在这些语言中,两个异常都会同时抛出,并且异常顺序是先“try”,然后“finally”。 (3认同)

Mat*_*nen 68

它就在那里,因为db.cleanup()即使try块中的代码抛出异常,程序员也希望确保调用它.该块不会处理任何异常,但它们只会在执行finally块后向上传播.

  • 确切地说+1.`try`就是允许`finally`.没有抓住例外情况. (21认同)
  • +1表示清除异常继续向上堆栈直到它被捕获.谢谢 (2认同)

Kon*_*lph 20

为什么这段代码会这样做?

因为显然代码不知道如何在这个级别处理异常.这很好 - 只要其中一个调用者执行,即只要异常最终在某处处理.

通常,低级代码无法对异常做出适当的反应,因为需要通知用户,或者必须记录异常,或者必须尝试其他策略.低级代码仅执行一个功能,并且不了解更高级别的决策.

但是代码仍然需要清理它的资源(因为如果没有,它们会泄漏),所以它只是在finally子句中执行,确保它始终发生,无论是否抛出异常.