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进行投诉反馈,一经查实,立即删除!