在Java中进行注释处理期间发生错误时,如何打印堆栈跟踪

时间:2018-07-31 21:16:32

标签: java annotation-processing annotation-processor

我正在使用具有注释处理器的Java library。为了捕获异常,我编写了类似于以下代码的代码:

public class KriptonProcessor extends AbstractProcessor {

  @Override
  public boolean process(final Set<? extends TypeElement> annotations, final RoundEnvironment roundEnv) {
    try {
        ...
        return true;
    } catch (Throwable e) {
        String msg = StringUtils.nvl(e.getMessage());
        error(null, e.getClass().getCanonicalName() + ": " + msg);
        e.printStackTrace();

    }

    return true;
  }
}

发生异常时,实际上显示为:

e: error: java.lang.NullPointerException:

虽然我期待完整的堆栈跟踪,但对于检测问题出在哪里很有用。有什么想法可以完成这项任务吗?

谢谢。

1 个答案:

答案 0 :(得分:0)

public class KriptonProcessor extends AbstractProcessor {

  @Override
  public boolean process(final Set<? extends TypeElement> annotations, final RoundEnvironment roundEnv) {
    try {
        ...
        return true;
    } catch (Throwable e) {
        e.printStackTrace();
        return false;

    }

    return true;
  }
}