1 多个异常块 catch 写法
参考 Nacos 的 nacos-config 子项的 BaseDatabaseOperate 类。
default Boolean update(TransactionTemplate transactionTemplate, JdbcTemplate jdbcTemplate,List<ModifyRequest> contexts, BiConsumer<Boolean, Throwable> consumer)
try {
return Boolean.TRUE;
} catch (BadSqlGrammarException | DataIntegrityViolationException e) {
FATAL_LOG.error("[db-error] sql : {}, args : {}, error : {}", errSql[0], args[0], e.toString());
return Boolean.FALSE;
}
当我们有多个异常需要相同异常处理时,可以采用 catch(XxxException | XxxExcetion) 方式处理,代码看起来也非常简洁和优雅。
2 资源关闭 try-with-resource
在 Jdk 1.7之后有了 try-with-resource 处理机制。
本地代码参考 Nacos 批量上传配置文件接口,关闭资源写法
try (DiskUtils.LineIterator iterator = DiskUtils.lineIterator(file)) {
int batchSize = 1000;
List<String> batchUpdate = new ArrayList<>(batchSize);
List<CompletableFuture<Void>> futures = new ArrayList<>();
List<Boolean> results = new CopyOnWriteArrayList<>();
while (iterator.hasNext()) {
String sql = iterator.next();
if (StringUtils.isNotBlank(sql)) {
batchUpdate.add(sql);
}
if (batchUpdate.size() == batchSize || !iterator.hasNext()) {
List<ModifyRequest> sqls = batchUpdate.stream().map(s -> {
ModifyRequest request = new ModifyRequest();
request.setSql(s);
return request;
}).collect(Collectors.toList());
futures.add(CompletableFuture.runAsync(() -> results.add(doDataImport(jdbcTemplate, sqls))));
batchUpdate.clear();
}
}
CompletableFuture.allOf(futures.toArray(new CompletableFuture[0])).join();
return RestResult.<String>builder()
.withCode(BooleanUtils.and(results.toArray(new Boolean[0])) ? 200 : 500).withData("").build();
} catch (Throwable ex) {
LogUtil.DEFAULT_LOG.error("An exception occurred when external data was imported into Derby : {}", ex);
return RestResultUtils.failed(ex.getMessage());
}
示例代码 try (DiskUtils.LineIterator iterator = DiskUtils.lineIterator(file)) 包含文件流读取,所以符合 try-with-resource,不需要开发者手动关闭文件流资源。
该博客介绍了Java中两种高效处理异常的方式:1) 使用`catch (XxxException | XxxException)`来捕获并处理多个相似异常,使得代码更简洁。2) 利用JDK 1.7引入的`try-with-resource`特性自动关闭资源,如文件流,避免资源泄露。示例代码展示了如何在批量数据导入场景中应用这些技巧。
1369

被折叠的 条评论
为什么被折叠?



