1 回答

TA貢獻(xiàn)1864條經(jīng)驗(yàn) 獲得超6個(gè)贊
我想到了用Consumer來(lái)告訴成功和失敗,但是還有其他方法嗎?
你不需要趕上SQLException??梢韵胂螅梢宰屗鼈鞑サ娇梢赃m當(dāng)處理的更高級(jí)別。
或者,您可以拋出一個(gè)新的異常。例如:
public void setGlobalSetting(Setting setting) throws MyException {
if(setting.getId() == 0) {
try {
...
ps.executeUpdate();
} catch (SQLException e) {
throw new MyException("Cannot set setting due to database error", e);
}
} else {
...
}
}
在此上下文中可能存在一個(gè)合理的拋出異常。如果不是,請(qǐng)聲明您自己的異常類。
如果您認(rèn)為調(diào)用者需要嘗試從中恢復(fù),則檢查異常是合適的。否則使用未經(jīng)檢查的異常。
要點(diǎn)是你的代碼不應(yīng)該捕獲異常,除非它能夠處理它。打印堆棧跟蹤并繼續(xù)執(zhí)行很少是處理異常的正確方法。
添加回答
舉報(bào)