溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java如何獲取異常堆棧信息

發(fā)布時間:2021-08-19 14:06:53 來源:億速云 閱讀:3232 作者:小新 欄目:編程語言

這篇文章主要介紹了Java如何獲取異常堆棧信息,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Java獲取異常堆棧信息的兩種方法,以下是全部內(nèi)容:

(stack trace)異常棧軌跡是指:

當(dāng)throw Throwable 時,Throwable對象拋出過程(穿梭)所經(jīng)歷的多個方法調(diào)用層(方法調(diào)用棧)。越接近 throw 語句的方法先進入異常棧。

(Throwable Causal Chain)異常原因鏈:

在Throwable類中的cause屬性,表示被當(dāng)前異常包裝的原始異常。(可以稱為異常原因)

在打印異常棧軌跡時,會遞歸打印 原始異常的異常棧。

現(xiàn)在來分析一下 Throwable.printStackTrace() 方法。

在Throwable.printStackTrace(PrintStreamOrWriter s) 內(nèi)部,我們可以看到:

在打印異常棧時,是先打印 當(dāng)前異常對象this的異常棧。

然后再打印 異常原因鏈。(遞歸打印 原始異常的異常棧)

synchronized (s.lock()) {
   // Print our stack trace
// 1. 先打印 當(dāng)前異常對象this的 異常棧。
   s.println(this);
   StackTraceElement[] trace = getOurStackTrace();
   for (StackTraceElement traceElement : trace)
    s.println("\tat " + traceElement);

   // Print suppressed exceptions, if any
   for (Throwable se : getSuppressed())
    se.printEnclosedStackTrace(s, trace, SUPPRESSED_CAPTION, "\t", dejaVu);
   // Print cause, if any
// 2. 打印 異常原因鏈
   Throwable ourCause = getCause();
   if (ourCause != null)
    ourCause.printEnclosedStackTrace(s, trace, CAUSE_CAPTION, "", dejaVu);
  }

Java獲取異常堆棧信息

方法一:

public static String getStackTrace(Throwable t) {
  StringWriter sw = new StringWriter();
  PrintWriter pw = new PrintWriter(sw);
  try {
    t.printStackTrace(pw);
    return sw.toString();
  } finally {
    pw.close();
  }
}

方法二:

org.apache.commons.lang3.exception.ExceptionUtils.getStackTrace(e);

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Java如何獲取異常堆棧信息”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI