1 回答

TA貢獻1829條經驗 獲得超7個贊
OmitStackTraceInFastThrow
是C2 編譯代碼中的優化,可拋出某些隱式異常,而無需堆棧跟蹤。該優化僅適用于隱式異常,即 JVM 本身引發的異常,而不是用戶代碼引發的異常。這些隱式異常是:
空指針異常
算術異常
ArrayIndexOutOfBoundsException
數組存儲異常
類轉換異常
僅當 JVM 知道該特定位置較早發生異常時,才會忽略堆棧跟蹤。
因此,在 HotSpot JVM 中,如果滿足以下所有條件,則異常不會有堆棧跟蹤: 1)拋出方法是熱的,即由 C2 編譯的; 2)它是一個隱式異常,例如由 拋出的 NPE obj.method()
,但不是由 拋出的throw new NullPointerException()
; 3)至少第二次拋出異常。
優化的目的是消除在快速路徑上重復拋出隱式異常時(可以說很少見)情況對性能的影響。在我看來,這不是正常情況。異常,尤其是隱式異常,通常表示需要修復的錯誤情況。從這個意義上說,禁用 是可以的-XX:-OmitStackTraceInFastThrow
。例如,在我們的生產環境中,我們總是禁用它,它節省了我們很多調試時間。不過,我承認,如果存在這樣的優化,那么在某些情況下它有助于解決性能問題。
TL;DR添加-XX:-OmitStackTraceInFastThrow
選項確實是一個好主意,除非應用程序中的熱路徑上存在許多隱式異常。
添加回答
舉報