Sto refactoring del codice per utilizzare guava Cache.Guava cache e conservazione delle eccezioni controllate
codice iniziale:
public Post getPost(Integer key) throws SQLException, IOException {
return PostsDB.findPostByID(key);
}
Per non rompere qualcosa che ho bisogno di conservare qualsiasi eccezione generata così com'è, senza avvolgendolo.
soluzione attuale appare un po 'brutta:
public Post getPost(final Integer key) throws SQLException, IOException {
try {
return cache.get(key, new Callable<Post>() {
@Override
public Post call() throws Exception {
return PostsDB.findPostByID(key);
}
});
} catch (ExecutionException e) {
Throwable cause = e.getCause();
if (cause instanceof SQLException) {
throw (SQLException) cause;
} else if (cause instanceof IOException) {
throw (IOException) cause;
} else if (cause instanceof RuntimeException) {
throw (RuntimeException) cause;
} else if (cause instanceof Error) {
throw (Error) cause;
} else {
throw new IllegalStateException(e);
}
}
}
C'è un modo possibile per renderlo più bello?
Esitato se la domanda con risposta personale deve essere inviata a tutti. Ma questo ha chiarito: http://meta.stackexchange.com/questions/2706/posting-and-answering-questions-you-have-already-found-the-answer-to – Vadzim
E grazie, ragazzi guava! – Vadzim
Quindi contrassegnalo come ** la ** risposta valida;) – Xaerxess