2

我只是在考虑 java 异常。有许多不同的类型,它们都各司其职。我很好奇的是他们的处理方式。例如

try
{
    //Protected code
}catch(ExceptionName e1)
{
    //Catch block
}

在 catch 块中,有多种方法可以报告异常。我找到了几个,但我认为还有更多:

  • System.err.println(e1);用于调试
  • system.println.out(e1);仅查看错误以进行本地验证
  • e1.printStackTrace();只查看错误
  • Logger.getLogger(classname.class.getName()).log(Level.SEVERE, null, e1);如果我是正确的,调试、信息和错误的级别可能会有所不同。

为什么你会选择一个而不是另一个?我能想到的只是它报告的信息吗?因此,对于简短的错误,您只需打印异常,而在寻找实际问题时,您将使用更大的错误。如果你知道会有例外,但不认为它很重要,可以直接抛出它吗?

异常处理是测试代码的好工具吗?可以代替Black-Box-testing吗?

4

1 回答 1

1

您的问题主要是关于日志记录的,根据您的要求和应用程序的复杂性,有几种方法可以做到这一点。它们之间显然存在差异,例如:

System.out.println()使用 Scanner 类的PrintStream 输出静态对象将传递的参数打印到控制台。println()PrintStream类的一种方法。绝对不是一个合适的日志记录解决方案。

System.println.out()我认为 System 类中不存在这样的方法,请参阅文档

System.err.println()确实存在,并且又是PrintStream类的静态对象。这是标准错误输出流,它已经打开,正在等待接收应该引起用户注意的数据。

如果您使用控制台,您将无法看到err.println()out.println()之间的区别。您显然可以配置它们,以便err.println()在文件中输出所有错误。

Java 的Exception类扩展了 Throwable并实现了 Serializable接口。Exception 从 Throwable 类继承了以下所有方法:

  • getCause() - 如果原因不存在,则返回 Throwable 或 null
  • getMessage() - 返回此 throwable 详细信息的字符串消息
  • getStackTrace() - 返回 throwable 的 StackTraceElement[]
  • printStackTrace() - 有以下两种变体

getStackTrace()使您能够以编程方式访问堆栈跟踪。

返回堆栈跟踪元素的数组,每个元素代表一个堆栈帧。数组的第零个元素(假设数组的长度不为零)表示堆栈的顶部,这是序列中的最后一个方法调用。通常,这是这个 throwable 被创建和抛出的点。数组的最后一个元素(假设数组的长度不为零)表示堆栈的底部,这是序列中的第一个方法调用。

printStackTrace() 或 printStackTrace(PrintStream s)没有 PrintStream 参数的第一个在标准错误输出流中打印堆栈跟踪(正确猜测!即err.println())。如果我们希望在文件中打印堆栈跟踪,我们传递 printStackTrace() 方法 PrintStream 指向一个文件或其他目的地。

好的,现在回到日志记录。有几个日志框架允许您以不同的严重级别记录数据。例如,您有一个企业应用程序,您希望根据以下数据记录数据

  • 严重(最高)
  • 警告
  • 信息
  • 其他级别

日志框架可以用来做很多事情,下面列出了一些:

  • 记录简单的文本消息
  • 日志级别过滤不同的日志消息
  • 日志类别
  • 日志文件轮换
  • 能够加载配置的配置配置文件
  • 庞大的名单还在继续

根据您正在开发的应用程序的要求,您可以使用一堆日志框架:

  1. 日志4j
  2. Java 日志记录 API
  3. Apache Commons API
  4. 在此处此处查看更多信息

其中一些日志框架有基准测试结果,例如,请参阅此处以比较 Log4j、Logback 和 Java Logging API。

您有很多选项可供选择,具体取决于项目的需要、项目的复杂性和您希望达到的日志记录级别。

Exception handling good for testing? No. 
Is logging good for testing? No.

异常处理是当您处理意外情况时。例如,您期望整数输入,然后您得到字符串。如果您不处理这种情况,则执行会中断,因此,您编写 try 和 catch 块来捕获此类异常,然后警告用户她/他应该只输入一个整数。像这样有很多异常,异常会导致代码的执行停止。如果用户能够停止执行您的代码,那么这不是一个好的程序,因此,您需要异常处理才能处理任何类型的用户、输入的数据等。

您不能使用异常处理进行测试,但它确实对您有所帮助。如何?异常处理可以与测试框架一起使用,以帮助您手动抛出不同类型的异常,然后使用您的异常处理代码进行处理。

日志不能用于测试,但可以与测试一起使用。您可以将日志框架与 JUnit 等测试框架一起使用,以便运行测试并记录在测试执行期间发生的所有事件。您可以配置您的日志框架以在每次执行测试时创建一组特殊的日志文件。

如果您希望进行日志记录并希望将来成为一名程序员(您可能已经是),那么您肯定需要使用测试框架进行测试,使用日志框架进行日志记录和异常处理来处理异常。

于 2015-11-24T11:08:10.983 回答