0

我的要求是在出现异常时发送自动邮件

public Connection dbConnect(String dbconnectionstring,String userid,String userpassword)
{
    Connection connection = null;
    System.out.println();
  try {
     Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver").newInstance();
     connection = DriverManager.getConnection(dbconnectionstring,userid,userpassword);
     System.out.println("connected to" + dbconnectionstring );

    } catch (InstantiationException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (IllegalAccessException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (ClassNotFoundException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

  return connection;

现在在另一个类中,如果我想访问异常 e 的内容(如果引发任何异常),应该在我的代码中编写什么来知道是否引发了任何异常?如果出现异常,则应邮寄 e 的内容。

4

3 回答 3

1

重新抛出相同的异常,或将其包装在特定于应用程序的异常类中(我的偏好):

    ...
} catch (InstantiationException e) {
    ...
    throw new MyAppException(e);
}
于 2012-09-10T11:11:54.627 回答
1

这取决于“其他”是什么。如果它是您的doConnect()方法的调用者,请不要捕获异常,而是将它们抛出并在调用者方法中捕获:

public void doConnect(....) throws InstantiationException, IllegalAccessException, .......{
}

public void theCaller() {
    try {
    doConnect(......)
    } catch(InstantiationException e) {
    }
    } catch(IllegalAccessException e) {
    }
/// etc
}

顺便说一句,在 java 7 中,您可以在一个块中捕获所有异常:

} catch(IllegalAccessException | InstantioationException | SqlException e)

或者,您可以使用可以检查或未检查(运行时)的其他异常来包装特定异常,例如

public Connection dbConnect(String dbconnectionstring,String userid,String userpassword)
{
    Connection connection = null;
    System.out.println();
  try {
     Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver").newInstance();
     connection = DriverManager.getConnection(dbconnectionstring,userid,userpassword);
     System.out.println("connected to" + dbconnectionstring );

    } catch (InstantiationException | IllegalAccessException  | ClassNotFoundException  | SQLException e) {
        throw new IllegalStateException("Connection failure", e);
    }

  return connection;
}

现在调用者可以捕获IllegalStateException并提取其原因。

但是,如果您需要某种管理所有异常的异步侦听器,您可以实现一个类ExceptionManager,当异常发生时,其他类正在更新该类。可能是单例的ExceptionManager,所以代码如下所示:

public void doConnect() {
    try {
       doConnect(......)
    catch(IllegalAccessException | InstantiationException | SqlException e)
        ExceptionManager.getInstance().exceptionThrown(e);
    }
}
于 2012-09-10T11:19:42.513 回答
0

你可以把它设计成一个日志管理器:获取你的报表类的应用级实例,并在异常处理中,让它处理异常。

或者您可以重新抛出异常并在应用程序的最高级别捕获它,它可以处理任何意外异常(在 Swing 应用程序中使用以避免关闭简单的 NPE)。

于 2012-09-10T11:14:07.243 回答