使用Java Annotation不运行方法

Mic*_*Mao 2 java annotations

我的课程中只有一个方法用于测试目的:

private void printOut(String msg, Object value)
{
    System.out.println(msg + value);
}
Run Code Online (Sandbox Code Playgroud)

它是System.out.println()的包装方法;

所以我希望,通过使用Annotation,我可以选择不在生产环境中运行此方法,同时如果我要切换回调试环境,仍然保持这些诊断输出准备就绪.

我应该在方法名称之上放置哪个注释?

uth*_*ark 11

如上所述,您应该使用日志记录.以下是在应用程序中使用日志记录的一些好处:

  • 日志记录可以生成有关应用程序操作的详细信息.
  • 一旦添加到应用程序,日志记录不需要人为干预.
  • 应用程序日志可以在以后保存和研究.
  • 如果足够详细且格式正确,应用程序日志可以提供审计跟踪.
  • 通过捕获可能未向用户报告的错误,日志记录可以帮助支持人员进行故障排除.
  • 通过捕获非常详细和程序员指定的消息,日志记录可以帮助程序员进行调试.
  • 日志记录可以是调试器不可用的调试工具,多线程或分布式应用程序通常就是这种情况.
  • 日志记录保留在应用程序中,可以在应用程序运行时随时使用.

阅读更多关于登录的信息

java中有很多日志框架:

  1. Log4j的
  2. java.util.logging中
  3. Logback.

还有几个外观,它们为各种日志框架提供了抽象:

  1. SLF4J
  2. 共享记录


Jam*_*ack 8

一种解决方案是使用AspectJ来执行此操作,因为您可以基于注释控制行为.

这是一个关于如何使用注释作为连接点的教程:

http://www.eclipse.org/aspectj//doc/next/adk15notebook/annotations-pointcuts-and-advice.html

你能做的是:

@DebugMessage
private void printOut(String msg, Object value)
{ }
Run Code Online (Sandbox Code Playgroud)

然后,在您的方面,您可以让方面进行println呼叫.

这样,在生产中,方面不包括在内,但是,如果您需要将此方法设置为活动,那么只需添加方面,甚至是生产代码,以获得一些调试.