簡體   English   中英

如何在catch子句之外記錄堆棧跟蹤

[英]How to log stack trace outside of catch clause

對於從不同站點調用的方法中很少發生的情況,我想在日志中進行堆棧跟蹤。 異常情況是通過異常檢測到的,即沒有try-catch。

我知道的唯一方法是使用偽造的異常,如下所示:

static void logWithStacktrace(Logger logger, Priority p, String msg) {
    try {
        throw new AssertionError();
    } catch (AssertionError e) {
        logger.log(p, msg, e);
    }
}

是否有一個很好的方法可以做到這一點而又不會引發異常? 也許有一個我忽略的log4j功能? 我正在尋找一種解決方案,該解決方案可將堆棧跟蹤的格式設置為真實異常消息中的格式-理想情況下,它將最終以XML日志文件中的<log4j:throwable>元素結尾。 我自己使用Thread.getStackTrace進行格式化並不允許我這樣做。

我知道,“很少發生”的尖叫聲要求代碼重構為使用異常。 另一方面,由於異常不是真正的錯誤,而是表示API使用存在問題,因此我只需要記錄這些異常。 因此,似乎將其設計為不直接對其進行記錄。

一些log4j方法接受Throwable對象。 Throwable包含創建時其線程的執行堆棧的快照。 您應該能夠如下使用它:

static void logWithStacktrace(Logger logger, Priority p, String msg) {
    logger.log(p, msg, new Exception());
}

您可以嘗試以下方法:

Thread.currentThread().getStackTrace();

這將返回一個StackTraceElement數組,您可以根據需要進行循環處理。 請注意,第一個元素通常是getStackTrace()調用,因此您可能要跳過它。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM