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
,不需要开发者手动关闭文件流资源。
往期推荐
- 肝九千字长文 | MyBatis-Plus 码之重器 lambda 表达式使用指南,开发效率瞬间提升80%
- 用 MHA 做 MySQL 读写分离,频繁爆发线上生产事故后,泪奔分享 Druid 连接池参数优化实战
- 微服务架构下,解决数据库跨库查询的一些思路
- 一文读懂阿里大中台、小前台战略
< END >