4 回答

TA貢獻1815條經驗 獲得超13個贊
您應該促進一個日志框架來執行此操作。根據您使用的是哪個,它看起來像logger.warn("Callback fired more then once.")
. 如果您還需要堆棧跟蹤,則可以將其添加到日志消息中。如果沒有涉及可能在某些時候變得不方便的日志記錄框架,您可以將警告打印到標準輸出:System.out.println("Warning: Callback fired more than once.")

TA貢獻1848條經驗 獲得超10個贊
您可以創建自己的異常類型
public class Warning extends RuntimeException {
//override constructors
}
然后你就可以做類似的事情
new Warning("Warning: Callback fired more than once.").printStackTrace(System.err);

TA貢獻1851條經驗 獲得超3個贊
你不能。
以便打印出來:
java.lang.Warning:
java.lang 包是“密封的”,您不能創建自己的類,這些類存在于該包中。
從這個角度來看,你能做到的最好的事情就是創建你自己的子類RuntimeException
,最終得到
your.com.whatever.Warning: Warning
除此之外,其他答案都是正確的:這是一個已解決的問題。你將要重新發明輪子,所以真正的答案是退后一步,研究日志框架,并使用一個。并且首先研究如何使用Java異常,你的代碼拋出錯誤實例是完全錯誤的!對于嚴重的錯誤情況,錯誤是 JVM 本身拋出的非常糟糕的事情。它們不應該用于代碼中的錯誤,或者您在此處考慮的任何類型的斷言。

TA貢獻1804條經驗 獲得超2個贊
不能直接這樣做,一種可能的方法是使用記錄器:
public static void main(String[] args) {
java.util.logging.Logger logger = java.util.logging.Logger.getLogger("");
logger.warning("warn message");
}
添加回答
舉報