如何仅使用 try-catch-finally 构造用两个资源重写 try-with-resources?

How to rewrite try-with-resources with two resources using only try-catch-finally construction?

如何改写下面的代码

try (A a = new A(); B b = new B()) {
//useful work here
}
catch (Exception e) {
//other code
}

使用 try-catch-finally 构造?

如果我们只创建一个资源,那么很好 link here

不幸的是,当我们创建多个资源时,我不明白如何概括这一点。

我不明白的一件事是,我们如何识别发生在 a 而未发生在 'b' 上的事情,反之亦然。

没有通用规则,但您必须确保您尝试关闭所有打开的资源,即使您不知道发生了什么以及在哪个资源中。

 void test() throws Exception {
    A a = null;
    B b = null;

    Exception myException = null;
    try {
        a = new A();
        b = new B();
        //useful work here
    } catch (Exception e) {
        myException = e;
        throw e;
    } finally {
        Throwable tA = handleCloaseable(a);
        Throwable tB = handleCloaseable(b);

        boolean throwIt = false;
        if (myException == null && tA != null || tB != null) {
            myException = new Exception();
            throwIt = true;
        }

        if (tA != null) {
            myException.addSuppressed(tA);
        }
        if (tB != null) {
            myException.addSuppressed(tB);
        }

        if (throwIt) {
            throw myException;
        }
    }
}

Throwable handleCloaseable(AutoCloseable e){ // your resources must implements AutoCloseable or Closeable
    if (e != null) {
        try {
            e.close();
        } catch (Throwable t) {
            return t;
        }
    }
    return null;
}

如果在您尝试关闭资源时发生任何异常,请创建新的 Exception 如果不存在并在您尝试使用 addSuppressed

关闭时添加异常