java多泛型、钩子函数实战记录
2023-12-13 18:31:15
1、调用示例
List<VehicleImportDto> list = commonApproveFunctionUtil.excelImportApprove(file, dto-> vehicleService.validateImportParams(dto), dto->{
Vehicle detail=new Vehicle();
BeanUtils.copyProperties(dto, detail);
return detail;
}, vehicleService,2, VehicleImportDto.class);
2、多泛型方法
/**
* 校验备件数据,并返回
* @param <D> 备件
* @param file 文件
* @param validateParamsPlan 校验规则
* @param headRowNumber 从第几行开始识别
* @param clazz excel实体接受对象
* @return
*/
public <D extends BaseIdEntity, T> List<T> excelImportApprove(MultipartFile file,
Predicate<T> validateParamsPlan,
Function<T, D> function,
IService<D> iService,
int headRowNumber, Class<T> clazz) {
List<D> result = new LinkedList<>();
AtomicReference<List<T>> result1=new AtomicReference<>();
try {
EasyExcel.read(file.getInputStream(), clazz, new PageReadListener<T>(dataList -> {
for(T dto: dataList){
// 特定校验,没通过直接返回
if( validateParamsPlan!=null && validateParamsPlan.test(dto)){
continue;
}
// 调用一下自定义生成的实体
D d = function.apply(dto);
result.add(d);
// 每一千条插入一次
if(result.size() !=0 && result.size()%1000 ==0){
iService.saveBatch(result);
result.clear();
}
}
result1.set(dataList);
})).mandatoryUseInputStream(true).sheet().headRowNumber(headRowNumber).doRead();
}catch (Exception e){
e.printStackTrace();
}
if(!result.isEmpty()){
iService.saveBatch(result);
}
return result1.get();
}
?3、核心知识点
(1)、?<D extends BaseIdEntity, T>? ?多泛型,需要用逗号隔开,必须在方法前面定义
(2)、?Predicate是自定义验证类,可以在使用此方法时用lambda表达式,自定义验证
(3)、?Function<T, D>,可以传入D对象,返回T对象
文章来源:https://blog.csdn.net/qq_34794385/article/details/134941371
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!