Java泛型–BeanUtils.copyProperties引发的血案

Java泛型–BeanUtils.copyProperties引发的血案BeanUtils copyProperti 引发的血案在一次使用 BeanUtils copyProperti 的方法是 莫名其妙的报错 在

大家好,欢迎来到IT知识分享网。

BeanUtils.copyProperties引发的血案

在一次使用BeanUtils.copyProperties的方法是,莫名其妙的报错,产生的代码分解如下:

Java泛型--BeanUtils.copyProperties引发的血案

 EntityA entityA = new EntityA(); List       uniteAList = new ArrayList<>(); for (int i = 0; i < 10; i++) { UniteA uniteA = new UniteA(); uniteA.setAge(i); uniteA.setName("name" + i); uniteAList.add(uniteA); } entityA.setKey(10); entityA.setUniteList(uniteAList);   

把EntityA的值赋值给EntityB:

 EntityB entityB = new EntityB(); BeanUtils.copyProperties(entityA, entityB); System.out.println(entityB.getUniteList().get(0).getClass()); 

在运行这段代码的时候,发生了异常的信息:

Java泛型--BeanUtils.copyProperties引发的血案

对于这个异常,我观察了很久,在调试的时候发现,EntityA中的UniteA中的字段竟然能够赋值给 EntityB中UnitB中的字段!! 类型不一样,竟能够存储!!

Java泛型--BeanUtils.copyProperties引发的血案

泛型仅仅适用于编译期


对于这个问题,归根于Java的泛型的特点,泛型仅仅适用于编译期,下面我们写几个代码来验证这个问题:

 List 
   
     strList=new ArrayList<>(); strList.add("1234");//正常的编译 strList.add(1234);//编译不能通过 
   

上面的例子我们可以看到List的类型的集合无法直接添加一个整型数据,但这个仅仅在编译的才校验,我们可以是有反射绕过这个验证。

List 
   
     strList=new ArrayList<>(); strList.add("1234");//正常的编译 try { Method method=strList.getClass().getDeclaredMethod("add",Object.class); method.invoke(strList,1234); System.out.println(strList); } catch (Exception e) { e.printStackTrace(); } 
   

调试信息如下:

Java泛型--BeanUtils.copyProperties引发的血案

同样,我们也可以使用如下代码验证上面的结论:

 List 
   
     strList=new ArrayList<>(); List 
    
      intList=new ArrayList<>(); System.out.println(strList.getClass().equals(intList.getClass())); 
     
   

打印结果为:true

(本文完)

点击右上角关注作者,加关注不迷路,欢迎交流

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/46093.html

(0)
上一篇 2026-04-07 13:45
下一篇 2026-04-08 10:45

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信