2024年最全Java反射+注解实现Entity类与Dto类相互转换,成功从小公司跳槽进蚂蚁定级P6

总目录展示

该笔记共八个节点(由浅入深),分为三大模块。

高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。

一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

由于内容太多,这里只截取部分的内容。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

return EnAndDtoMapper(entity, dto,true);

}

public static Object entryAndDtoMapper(Object entity, Object dto,boolean enToDto) throws Exception{

return EnAndDtoMapper(entity, dto,false);

}

//last version

public static Object EnAndDtoMapper(Object entry, Object dto,boolean enToDto) throws Exception{

if(enToDto == true ? entry == null : dto == null){ return null;}

Class<? extends Object> entryclazz = entry.getClass();    //获取entity类

Class<? extends Object> dtoclazz = dto.getClass();    //获取dto类

boolean dtoExistAnno = dtoclazz.isAnnotationPresent(RelMapper.class);    //判断类上面是否有自定义注解

Field [] dtofds = dtoclazz.getDeclaredFields();    //dto fields

Field [] entryfds = entryclazz.getDeclaredFields();    //entity fields

Method entrys[] = entryclazz.getDeclaredMethods();    //entity methods

Method dtos[] = dtoclazz.getDeclaredMethods();    //dto methods

String mName,fieldName,dtoFieldType=null,entFieldType=null,dtoMapName = null,dtoFieldName =null;Object value = null;

for(Method m : (enToDto ? dtos : entrys)) {    //当 enToDto=true 此时是Entity转为Dto,遍历dto的属性

if((mName=m.getName()).startsWith(“set”)) {    //只进set方法

fieldName = mName.toLowerCase().charAt(3) + mName.substring(4,mName.length());  //通过set方法获得dto的属性名

tohere:

for(Field fd: dtofds) {

fd.setAccessible(true);    //setAccessible是启用和禁用访问安全检查的开关

if(fd.isAnnotationPresent(RelMapper.class)||dtoExistAnno){    //判断field上注解或类上面注解是否存在

//获取与Entity属性相匹配的映射值(两种情况:1.该field上注解的value值(Entity的field name 和Dto 的field name 不同)  2.该field本身(本身则是Entity的field name 和Dto 的field name 相同))

dtoMapName = fd.isAnnotationPresent(RelMapper.class) ? (fd.getAnnotation(RelMapper.class).value().toString().equals(“”)?fd.getName().toString():fd.getAnnotation(RelMapper.class).value().toString()):fd.getName().toString();

if(((enToDto ? fd.getName() : dtoMapName)).toString().equals(fieldName)) {

dtoFieldType = fd.getGenericType().toString().substring(fd.getGenericType().toString().lastIndexOf(“.”) + 1); // 获取dto属性的类型(如 private String field 结果 = String)

for(Field fe : entryfds) {

fe.setAccessible(true);

if(fe.getName().toString().equals(enToDto ? dtoMapName : fieldName) ) {//遍历Entity类的属性与dto属性注解中的value值匹配

entFieldType = fe.getGenericType().toString().substring(fe.getGenericType().toString().lastIndexOf(“.”) + 1); //获取Entity类属性类型

dtoFieldName = enToDto ? dtoMapName : fd.getName().toString();

break tohere;

}

}

}

}

}

if(dtoFieldName!= null && !dtoFieldName.equals(“null”)) {

for(Method md : (enToDto ? entrys : dtos)) {

if(md.getName().toUpperCase().equals(“GET”+dtoFieldName.toUpperCase())){

dtoFieldName = null;

if(md.invoke(enToDto ? entry : dto) == null) { break;} //去空操作

//Entity类field 与Dto类field类型不一致通过TypeProcessor处理转换

value = (entFieldType.equals(dtoFieldType))? md.invoke(enToDto ? entry : dto) :TypeProcessor(entFieldType, dtoFieldType,md.invoke(enToDto ? entry : dto),enToDto ? true : false);

m.invoke(enToDto ? dto : entry, value); //得到field的值 通过invoke()赋值给要转换类的对应属性

value = null;

break;

}

}

}

}

}

return enToDto ? dto : entry;

}

//类型转换处理

public static Object TypeProcessor(String entFieldType,String dtoFieldType, Object obj,boolean enToDto) {

if(entFieldType.equals(dtoFieldType)) return obj;

if(!entFieldType.equals(dtoFieldType)) {

switch(entFieldType) {

case “Date”:

return (enToDto)?TypeConverter.dateToString((Date) obj):TypeConverter.stringToDate(obj.toString());

case “Timestamp”:

return TypeConverter.timestampToTimestampString((Timestamp)obj);

case “Integer”:

return (enToDto) ? obj.toString() : Integer.parseInt((String)obj) ;

}

}

return obj;

}

上面EnAndDtoMapper()方法的实现是Entity和Dto之间互相转换结合在一起,enToDto = true 表示的是Entity转Dto实现,false则相反。

3、如何使用?

1)Entity类 与 Dto类对应

2)调用

public static void main(String[] args) {

//Entity数据转成Dto数据集

Person person = dao.getPersonRecord();

RelationMapperUtils.entryAndDtoMapper(person,new PersonDto());

//Dto数据转成Entity数据

RelationMapperUtils.entryAndDtoMapper(new Person(),personDto,false);

}

线程、数据库、算法、JVM、分布式、微服务、框架、Spring相关知识

一线互联网P7面试集锦+各种大厂面试集锦

学习笔记以及面试真题解析

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

5078164760)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 27
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值