BeanUtils.copyProperties复制boolean

时间: 2024-08-12 09:05:22 浏览: 26
`BeanUtils.copyProperties()` 是 Apache Commons BeanUtils 工具包提供的一个功能,用于将源对象(通常是 Map、Properties 或者已初始化的 Java bean)的属性值复制到目标对象上。对于 boolean 类型,`copyProperties()` 将直接进行赋值操作,即如果源对象的某个键对应的值是一个布尔值,它会把该布尔值设置为目标对象相应字段上。 例如,假设你有这样一个场景: ```java Map<String, Object> source = new HashMap<>(); source.put("isEnabled", true); // 源 map 中有一个 boolean 值 MyTargetObject target = new MyTargetObject(); // 目标对象 BeanUtils.copyProperties(target, source); ``` 在这个例子中,`isEnabled` 字段将会被 `target.isEnabled` 设定为 `true`。 需要注意的是,如果源值不是布尔类型,但在转换过程中能成功解析为布尔值(比如 "true"、"false"),则也能正常工作;但如果转换失败(如非字符串类型的无效值),可能会抛出异常。因此,在实际使用时,最好处理可能出现的异常。
相关问题

BeanUtils.copyProperties PropertyFilter

BeanUtils.copyProperties是Apache Commons BeanUtils库中的一个方法,用于将一个Java对象的属性值复制到另一个Java对象中。它可以方便地实现对象之间的属性拷贝,无需手动逐个设置属性值。 PropertyFilter是一个接口,用于在属性拷贝过程中进行过滤操作。它定义了一个方法,可以根据需要决定是否拷贝某个属性。通过实现PropertyFilter接口,可以自定义属性拷贝时的过滤规则。 以下是对BeanUtils.copyProperties和PropertyFilter的详细介绍: 1. BeanUtils.copyProperties: - 作用:将源对象的属性值复制到目标对象中。 - 使用方法:BeanUtils.copyProperties(Object dest, Object orig) - 参数说明: - dest:目标对象,即要将属性值复制到的对象。 - orig:源对象,即要从中复制属性值的对象。 - 注意事项: - 属性名和类型必须在源对象和目标对象中存在且匹配。 - 属性值会按照名称匹配进行复制,不会考虑类型转换。 2. PropertyFilter: - 作用:在属性拷贝过程中进行过滤操作。 - 接口定义:org.apache.commons.beanutils.PropertyUtilsBean.PropertyFilter - 方法定义:boolean apply(Object source, String name, Object value) - 参数说明: - source:源对象,即要从中复制属性值的对象。 - name:属性名。 - value:属性值。 - 返回值: - true:拷贝该属性。 - false:不拷贝该属性。

BeanUtils.copyProperties忽略null值

可以使用BeanMapper或者在BeanUtils.copyProperties中传入一个自定义的属性过滤器来忽略null值。以下是两种方法的示例代码: 1. 使用BeanMapper忽略null值 ```python import net.sf.cglib.beans.BeanCopier; import net.sf.cglib.core.Converter; public class BeanMapper { private static final Map<String, BeanCopier> BEAN_COPIERS = new ConcurrentHashMap<>(); public static void copyProperties(Object source, Object target) { String key = source.getClass().toString() + target.getClass().toString(); BeanCopier copier = null; if (!BEAN_COPIERS.containsKey(key)) { copier = BeanCopier.create(source.getClass(), target.getClass(), true); BEAN_COPIERS.put(key, copier); } else { copier = BEAN_COPIERS.get(key); } copier.copy(source, target, new Converter() { @Override public Object convert(Object value, Class target, Object context) { if (value == null) { if (target == String.class) { return ""; } else if (target == Integer.class) { return 0; } else if (target == Long.class) { return 0L; } else if (target == Double.class) { return 0.0; } else if (target == Float.class) { return 0.0f; } else if (target == Boolean.class) { return false; } else { return null; } } else { return value; } } }); } } ``` 使用示例: ```python Source source = new Source(); source.setName("test"); source.setAge(18); source.setAddress(null); Target target = new Target(); BeanMapper.copyProperties(source, target); System.out.println(target.getName()); // 输出:test System.out.println(target.getAge()); // 输出:18 System.out.println(target.getAddress()); // 输出:null ``` 2. 在BeanUtils.copyProperties中传入自定义属性过滤器忽略null值 ```python import org.springframework.beans.BeanUtils; import org.springframework.beans.BeanWrapper; import org.springframework.beans.BeanWrapperImpl; import java.beans.PropertyDescriptor; import java.util.HashSet; import java.util.Set; public class CopyUtils { public static void copyPropertiesIgnoreNull(Object source, Object target) { BeanUtils.copyProperties(source, target, getNullPropertyNames(source)); } private static String[] getNullPropertyNames(Object source) { final BeanWrapper src = new BeanWrapperImpl(source); PropertyDescriptor[] pds = src.getPropertyDescriptors(); Set<String> emptyNames = new HashSet<>(); for (PropertyDescriptor pd : pds) { Object srcValue = src.getPropertyValue(pd.getName()); if (srcValue == null) { emptyNames.add(pd.getName()); } } String[] result = new String[emptyNames.size()]; return emptyNames.toArray(result); } } ``` 使用示例: ```python Source source = new Source(); source.setName("test"); source.setAge(18); source.setAddress(null); Target target = new Target(); CopyUtils.copyPropertiesIgnoreNull(source, target); System.out.println(target.getName()); // 输出:test System.out.println(target.getAge()); // 输出:18 System.out.println(target.getAddress()); // 输出:null ```

相关推荐

帮我优化一下以下这段java代码 private boolean vaildRepeatData(RmMixModelAcceptDataDto rmMixModelAcceptDataDto) { AtomicBoolean result = new AtomicBoolean(false); Integer count = rmMixModelBaseDataDao.selectByAllInfo(rmMixModelAcceptDataDto,DateUtils.getMonth(new Date())); if (count > 0) { result.set(true); } List<RmMixModelAcceptDataDto.Contact> contactList = rmMixModelAcceptDataDto.getContactList(); if (CollectionUtil.isNotEmpty(contactList)) { List<RmMixModelRelationData> rmMixModelRelationDataLocalList = rmMixModelBaseRelationDataDao.selectRelationInfoByApplyNo(rmMixModelAcceptDataDto.getApplNo()); List<RmMixModelRelationData> rmMixModelRelationDataRmList = contactList.stream().map( contact -> { RmMixModelRelationData rmMixModelRelationData = new RmMixModelRelationData(); BeanUtils.copyProperties(contact, rmMixModelRelationData); rmMixModelRelationData.setApplNo(rmMixModelAcceptDataDto.getApplNo()); rmMixModelRelationData.setPMonth(DateUtils.getMonth(new Date())); String contactInfo = Constants.BLANK; try { contactInfo =cryptoConfiguration.hash(rmMixModelRelationData.getContactInfo()); } catch (SQLException e) { log.error("手机号hash加密失败! e:{}",e.getMessage()); } rmMixModelRelationData.setContactInfo(contactInfo); return rmMixModelRelationData; } ).collect(Collectors.toList()); if (rmMixModelRelationDataLocalList.size() != rmMixModelRelationDataRmList.size()){ result.set(false); }else { rmMixModelRelationDataLocalList.forEach( local ->{ for (RmMixModelRelation

public boolean addVideo(SysVideoSaveReq sysVideoInfo) { Common.logger.info("新增粒界axis入参:{}",sysVideoInfo); SysVideoInfo sysVideoInfo1 = new SysVideoInfo(); BeanUtils.copyProperties(sysVideoInfo,sysVideoInfo1); SysEquipmentInfo sysEquipmentInfo = equipmentInfoService.selectByDeviceId(sysVideoInfo.getStreamInfoId()); Common.logger.info("要修改的点位x-y-z轴:{}",sysEquipmentInfo); if (!ObjectUtils.isEmpty(sysEquipmentInfo)) { sysVideoInfo1.setVedioUrl(sysEquipmentInfo.getVedioUrl()); sysVideoInfo1.setPushRtmpUrl(sysEquipmentInfo.getPushRtmpUrl()); sysVideoInfo1.setLiveFlvUrl(sysEquipmentInfo.getLiveFlvUrl()); sysVideoInfo1.setLiveHlsUrl(sysEquipmentInfo.getLiveHlsUrl()); SetSysEquipmentReq setSysEquipmentReq = new SetSysEquipmentReq(); setSysEquipmentReq.setxAxis(sysVideoInfo1.getXAxis()); setSysEquipmentReq.setyAxis(sysVideoInfo1.getYAxis()); setSysEquipmentReq.setzAxis(sysVideoInfo1.getZAxis()); setSysEquipmentReq.setStreamInfoId(sysVideoInfo1.getStreamInfoId()); Common.logger.info("点位x-y-z轴:{}",setSysEquipmentReq); equipmentInfoService.setEquipmentAxis(setSysEquipmentReq); } sysVideoInfo1.setCreateTime(LocalDateTime.now()); SysVideoInfo sysVideoInfo2 = videoInfoMapper.selectOne(new LambdaQueryWrapper<SysVideoInfo>().eq(SysVideoInfo::getStreamInfoId, sysEquipmentInfo.getStreamInfoId())); if (!ObjectUtils.isEmpty(sysVideoInfo2)){ sysVideoInfo1.setId(sysVideoInfo2.getId()); } String s = HospitalTypeEnum.hospitalType(sysVideoInfo.getAreaType()); sysVideoInfo1.setAreaType(s); String s1 = BuildingCodeEnum.buildingName(sysVideoInfo.getCompanyId()); sysVideoInfo1.setCompanyId(s1); return this.saveOrUpdate(sysVideoInfo1); }解释下这段代码

帮我优化下面的java代码for (Object object : args) { if (object == null) { continue; } if(!dataPermissionSchemaEoMap.containsKey(databaseName+tableName)){ continue; } if (object instanceof BaseEo) { Class<?> aClass = object.getClass(); Object o = aClass.newInstance(); BeanUtils.copyProperties(object,o); //获取字段 Field[] fieldsAndParentsFields = ReflectionUtil.getFieldsAndParentsFields(o); //获取对应的行权限 DataPermissionSchemaEo dataPermissionSchemaEo = dataPermissionSchemaEoMap.get(databaseName + tableName); List<SchemaRowRuleEo> schemaRowRuleList = dataPermissionSchemaEo.getSchemaRowRuleList(); for (SchemaRowRuleEo schemaRowRuleEo : schemaRowRuleList) { //获取行规则要素 String filterConditionList = schemaRowRuleEo.getFilterConditionList(); List<SchemaRowFilterCondition> schemaRowFilterConditions = JSONObject.parseArray(filterConditionList, SchemaRowFilterCondition.class); for (SchemaRowFilterCondition schemaRowFilterCondition : schemaRowFilterConditions) { String field = schemaRowFilterCondition.getField(); String camel = underlineToCamel(field); String key = schemaRowFilterCondition.getKey(); //如果字段相等 for (Field fieldsAndParentsField : fieldsAndParentsFields) { if(StringUtils.equals(fieldsAndParentsField.getName(),camel) ){ Field f = aClass.getDeclaredField(camel); f.setAccessible(true); Object value = f.get(object); if(StringUtils.equals(key,value.toString()) && schemaRowRuleEo.getRowEditPermission() ){ System.out.println("修改成功"); }else { throw new CustomException("大马猴来了",code); } } } } } } }代码优化

@Data @ApiModel(value = "飞行任务管理-后端列表页vo") public class BisTaskVO extends PageReqVO implements Serializable { @ApiModelProperty(value = "id") private Integer id; @ApiModelProperty(value = "项目名称") private String projectName; @ApiModelProperty(value = "任务名称") private String taskName; @ApiModelProperty(value = "期望飞行开始时间") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8") private Date expectTaskStartDate; @ApiModelProperty(value = "实际飞行开始时间") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date actualTaskStartDate; @ApiModelProperty(value = "期望飞行结束时间") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8") private Date expectTaskEndDate; @ApiModelProperty(value = "实际飞行结束时间") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date actualTaskEndDate; @ApiModelProperty(value = "飞行地点") private String flyPlace; @ApiModelProperty(value = "任务创建时间") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date createTime; @ApiModelProperty(value = "任务修改时间") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date updateTime; @ApiModelProperty(value = "任务状态 1 待指派 2已指派 3已完成 4待飞行 5待上传 6已上传 7驳回 8审核通过") private Integer taskStatus; } 帮我写一个根据id修改,但是projectName是BisProject类的, BisTask类的id关联BisTaskTower类的taskId, BisTower类的id关联BisTaskTower类的Id, BisTower类的projectId关联BisProject类的id, 用mybtais-plus修改,不要写mapper和sql

最新推荐

recommend-type

用交流和直流网络实现的西景电气中的飞机电力网simulink实现.rar

1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
recommend-type

井下甲烷气体报警器研发(工程教育课程项目报告)

井下甲烷气体报警器研发(工程教育课程项目报告)
recommend-type

2023-04-06-项目笔记 - 第二百五十二阶段 - 4.4.2.20全局变量的作用域-250 -2025.09.10

2023-04-06-项目笔记-第二百五十二阶段-课前小分享_小分享1.坚持提交gitee 小分享2.作业中提交代码 小分享3.写代码注意代码风格 4.3.1变量的使用 4.4变量的作用域与生命周期 4.4.1局部变量的作用域 4.4.2全局变量的作用域 4.4.2.1全局变量的作用域_1 4.4.2.250局变量的作用域_250- 2024-09-10
recommend-type

028.jpg

028
recommend-type

【2024首发原创】蜣螂算法DBO-TCN-LSTM-Multihead-Attention时间序列预测.zip

CSDN海神之光上传的全部代码均可运行,亲测可用,直接替换数据即可,适合小白; 1、代码压缩包内容 主函数:Main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开除Main.m的其他m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 智能优化算法优化TCN-LSTM-Multihead-Attention回归预测系列程序定制或科研合作方向: 4.4.1 遗传算法GA/蚁群算法ACO优化TCN-LSTM-Multihead-Attention回归预测 4.4.2 粒子群算法PSO/蛙跳算法SFLA优化TCN-LSTM-Multihead-Attention回归预测 4.4.3 灰狼算法GWO/狼群算法WPA优化TCN-LSTM-Multihead-Attention回归预测 4.4.4 鲸鱼算法WOA/麻雀算法SSA优化TCN-LSTM-Multihead-Attention回归预测 4.4.5 萤火虫算法FA/差分算法DE优化TCN-LSTM-Multihead-Attention回归预测 4.4.6 其他优化算法优化TCN-LSTM-Multihead-Attention回归预测
recommend-type

解决本地连接丢失无法上网的问题

"解决本地连接丢失无法上网的问题" 本地连接是计算机中的一种网络连接方式,用于连接到互联网或局域网。但是,有时候本地连接可能会丢失或不可用,导致无法上网。本文将从最简单的方法开始,逐步解释如何解决本地连接丢失的问题。 **任务栏没有“本地连接”** 在某些情况下,任务栏中可能没有“本地连接”的选项,但是在右键“网上邻居”的“属性”中有“本地连接”。这是因为本地连接可能被隐藏或由病毒修改设置。解决方法是右键网上邻居—属性—打开网络连接窗口,右键“本地连接”—“属性”—将两者的勾勾打上,点击“确定”就OK了。 **无论何处都看不到“本地连接”字样** 如果在任务栏、右键“网上邻居”的“属性”中都看不到“本地连接”的选项,那么可能是硬件接触不良、驱动错误、服务被禁用或系统策略设定所致。解决方法可以从以下几个方面入手: **插拔一次网卡一次** 如果是独立网卡,本地连接的丢失多是因为网卡接触不良造成。解决方法是关机,拔掉主机后面的电源插头,打开主机,去掉网卡上固定的螺丝,将网卡小心拔掉。使用工具将主板灰尘清理干净,然后用橡皮将金属接触片擦一遍。将网卡向原位置插好,插电,开机测试。如果正常发现本地连接图标,则将机箱封好。 **查看设备管理器中查看本地连接设备状态** 右键“我的电脑”—“属性”—“硬件”—“设备管理器”—看设备列表中“网络适配器”一项中至少有一项。如果这里空空如也,那说明系统没有检测到网卡,右键最上面的小电脑的图标“扫描检测硬件改动”,检测一下。如果还是没有那么是硬件的接触问题或者网卡问题。 **查看网卡设备状态** 右键网络适配器中对应的网卡选择“属性”可以看到网卡的运行状况,包括状态、驱动、中断、电源控制等。如果发现提示不正常,可以尝试将驱动程序卸载,重启计算机。 本地连接丢失的问题可以通过简单的设置修改或硬件检查来解决。如果以上方法都无法解决问题,那么可能是硬件接口或者主板芯片出故障了,建议拿到专业的客服维修。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

Java泛型权威指南:精通从入门到企业级应用的10个关键点

![java 泛型数据结构](https://media.geeksforgeeks.org/wp-content/uploads/20210409185210/HowtoImplementStackinJavaUsingArrayandGenerics.jpg) # 1. Java泛型基础介绍 Java泛型是Java SE 1.5版本中引入的一个特性,旨在为Java编程语言引入参数化类型的概念。通过使用泛型,可以设计出类型安全的类、接口和方法。泛型减少了强制类型转换的需求,并提供了更好的代码复用能力。 ## 1.1 泛型的用途和优点 泛型的主要用途包括: - **类型安全**:泛型能
recommend-type

cuda下载后怎么通过anaconda关联进pycharm

CUDA(Compute Unified Device Architecture)是NVIDIA提供的一种并行计算平台和编程模型,用于加速GPU上进行的高性能计算任务。如果你想在PyCharm中使用CUDA,你需要先安装CUDA驱动和cuDNN库,然后配置Python环境来识别CUDA。 以下是步骤: 1. **安装CUDA和cuDNN**: - 访问NVIDIA官网下载CUDA Toolkit:https://www.nvidia.com/zh-cn/datacenter/cuda-downloads/ - 下载对应GPU型号和系统的版本,并按照安装向导安装。 - 安装
recommend-type

BIOS报警声音解析:故障原因与解决方法

BIOS报警声音是计算机启动过程中的一种重要提示机制,当硬件或软件出现问题时,它会发出特定的蜂鸣声,帮助用户识别故障源。本文主要针对常见的BIOS类型——AWARD、AMI和早期的POENIX(现已被AWARD收购)——进行详细的故障代码解读。 AWARDBIOS的报警声含义: 1. 1短声:系统正常启动,表示无问题。 2. 2短声:常规错误,需要进入CMOS Setup进行设置调整,可能是不正确的选项导致。 3. 1长1短:RAM或主板故障,尝试更换内存或检查主板。 4. 1长2短:显示器或显示卡错误,检查视频输出设备。 5. 1长3短:键盘控制器问题,检查主板接口或更换键盘。 6. 1长9短:主板FlashRAM或EPROM错误,BIOS损坏,更换FlashRAM。 7. 不断长响:内存条未插紧或损坏,需重新插入或更换。 8. 持续短响:电源或显示问题,检查所有连接线。 AMI BIOS的报警声含义: 1. 1短声:内存刷新失败,内存严重损坏,可能需要更换。 2. 2短声:内存奇偶校验错误,可关闭CMOS中的奇偶校验选项。 3. 3短声:系统基本内存检查失败,替换内存排查。 4. 4短声:系统时钟错误,可能涉及主板问题,建议维修或更换。 5. 5短声:CPU错误,可能是CPU、插座或其他组件问题,需进一步诊断。 6. 6短声:键盘控制器错误,检查键盘连接或更换新键盘。 7. 7短声:系统实模式错误,主板可能存在问题。 8. 8短声:显存读写错误,可能是显卡存储芯片损坏,更换故障芯片或修理显卡。 9. 9短声:ROM BIOS检验错误,需要替换相同型号的BIOS。 总结,BIOS报警声音是诊断计算机问题的重要线索,通过理解和识别不同长度和组合的蜂鸣声,用户可以快速定位到故障所在,采取相应的解决措施,确保计算机的正常运行。同时,对于不同类型的BIOS,其报警代码有所不同,因此熟悉这些代码对应的意义对于日常维护和故障排除至关重要。