原文链接:https://blog.csdn.net/eeeeasy/article/details/80999650?utm_source=blogxgwz2

在项目中遇到一个问题,想要封装一个通用的可接收任意类型的List对象的方法,最开始以为很容易实现,

通过List<Object>就可接收任意List<实体类>的对象,后来发现这根本行不通,最开始的思路如下

List<Student> list = new ArrayList<Student>();
List<Object> objList = list;

上面这种作为是错误的,无法转型,后来思考了一下,把List<Object>作为一个整体类型来看,他和List<实体类>确实是不存在任何关系的,并没有最开始认为的存在上下级关系,可以实现多态向上转型,所以后来想到用泛型来解决这个问题,还额外想到了另外两种方式,代码如下:

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List; /**
* @Auther: HeJD
* @Date: 2018/7/4 11:30
* @Description:
*/
public class OrderService { //方式一:
public static <T> void testList(List<T> list){ for (Object object:list) {
System.out.println(object.toString());
} }
//方式二:
public static void testList2(List list){ for (Object object:list) {
System.out.println(object.toString()); // begin---------------------> 这里是我测试一下反射的使用的,不用请忽略
//通过反射获得object对象对应的实体类的属性、及属性值
try{
//获得object对象对应的所有已申明的属性,包括public、private、和protected
Field [] fields = object.getClass().getDeclaredFields(); for (Field field:fields) { //不加这一句 private的属性无法访问的呀
field.setAccessible(true);
//获得属性名称
System.out.println("获得属性名:"+ field.getName());
//获得属性值
System.out.println("获得属性值:"+ field.get(object)); } }catch (Exception e){
e.printStackTrace();
}
//参考博主反射连接:https://blog.csdn.net/lotusyangjun/article/details/51957374
// end---------------------> 这里是我测试一下反射的使用的,不用请忽略
} }
//方式三:
public static void testList3(List<?> list) throws Exception{ for (Object object:list) {
System.out.println(object.toString()); } }
public static void main(String[] args) throws Exception { List<Student> listStudent=new ArrayList<>();
listStudent.add(new Student("王老板",50));
listStudent.add(new Student("李老板",60));
listStudent.add(new Student("河老板",70)); testList2(listStudent);
}
}

实体类也贴一下:

/**
* @Auther: HeJD
* @Date: 2018/7/11 14:18
* @Description:
*/
public class Student {
private String name;
private int age; public Student(String name, int age) {
this.name = name;
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}

结果:

用了反射的结果也记录一下:

List作为泛型参数实现可接收存储任意类型的List对象的更多相关文章

  1. Java基础 -- 泛型之泛型参数

    泛型机制常用的参数有3个: “?”代表任意类型.如果只指定了<?>,而没有extends,则默认是允许任意类. extends关键字声明了类型的上界,表示参数化的类型可能是所指定的类型,或 ...

  2. 编写高质量代码改善C#程序的157个建议[优先考虑泛型、避免在泛型中声明静态成员、为泛型参数设定约束]

    前言 泛型并不是C#语言一开始就带有的特性,而是在FCL2.0之后实现的新功能.基于泛型,我们得以将类型参数化,以便更大范围地进行代码复用.同时,它减少了泛型类及泛型方法中的转型,确保了类型安全.委托 ...

  3. Gson通过借助TypeToken获取泛型参数的类型的方法

    最近在使用Google的Gson包进行Json和Java对象之间的转化,对于包含泛型的类的序列化和反序列化Gson也提供了很好的支持,感觉有点意思,就花时间研究了一下. 由于Java泛型的实现机制,使 ...

  4. Gson通过借助TypeToken获取泛型参数的类型的方法(转)

    最近在使用Google的Gson包进行Json和Java对象之间的转化,对于包含泛型的类的序列化和反序列化Gson也提供了很好的支持,感觉有点意思,就花时间研究了一下. 由于Java泛型的实现机制,使 ...

  5. 编写高质量代码改善C#程序的157个建议——建议42:使用泛型参数兼容泛型接口的不可变性

    建议42:使用泛型参数兼容泛型接口的不可变性 让返回值类型返回比声明的类型派生程度更大的类型,就是“协变”.如: public Employee GetAEmployee(string name) { ...

  6. springMVC 接收数组参数,mybatis 接收数组参数,mybatis批量插入/批量删除案例

    案例是给一个用户赋予多个权限,多个权限用其对应的主键 id 为参数,组成了 一个id数组,传给springMVC,然后springMVC传给mybatis,然后mybatis批量插入.其实类似的场景还 ...

  7. 通过反射获取父类中的泛型参数对应的Class对象

    假设有两个类:Dao 和 PersonDao,它们的代码如下: Dao: public class Dao<T> { private Class<T> clazz; T get ...

  8. Happy Java:定义泛型参数的方法

    在平时写代码时,可以自定义泛型类.当使用同一类型的对象时,这是非常有用的,但在实例化类之前,我们不知道它将是哪种类型. 下面让我们定义一个使用泛型参数的方法.首先,在定义一个类用到泛型时,必须使用特殊 ...

  9. ParameterizedType获取java泛型参数类型

    ParameterizedType getClass().getGenericSuperclass() 返回表示此 Class 所表示的实体(类.接口.基本类型或 void)的直接超类的 Type,然 ...

随机推荐

  1. HDU5293 树链剖分+树形DP

    =-=抓住叶节点往上揪 Tree chain problem Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K ...

  2. Align Content Properties

    How to align the items of the flexible element? <!DOCTYPE html> <html lang="en"&g ...

  3. Java——动态创建Class(不写入文件,直接从内存中创建class)

    原文:https://blog.csdn.net/zhao_xinhu/article/details/82499062#commentsedit 参考:https://www.cnblogs.com ...

  4. 解决linux下启动tomcat找不到jdk

    在tomcat目录下 vim catalina.sh 头部加入 JAVA_HOME='/root/use/local/java/jdk/';export JAVA_HOME;

  5. akka-typed(1) - actor生命周期管理

    akka-typed的actor从创建.启用.状态转换.停用.监视等生命周期管理方式和akka-classic还是有一定的不同之处.这篇我们就介绍一下akka-typed的actor生命周期管理. 每 ...

  6. 派生类Student的构造函数和析构函数 代码参考

    #include <iostream> #include <cstring> using namespace std; class Person { private: char ...

  7. Autofac依赖注入

    简介 Autofac 是一款超赞的.NET IoC 容器 . 它管理类之间的依赖关系, 从而使 应用在规模及复杂性增长的情况下依然可以轻易地修改 .它的实现方式是将常规的.net类当做 组件 处理. ...

  8. Rocket - diplomacy - MixedNode

    https://mp.weixin.qq.com/s/zgeAI2n-2cHJi7-Ra5rYZA   介绍MixedNode的实现.     1. 类定义   ​​ ​​   2. inner/ou ...

  9. 拨开云雾-Verilog是个大杂烩(中性)

    https://mp.weixin.qq.com/s/HKxX_79DtnXmFU1Mwt1GwA   一. 有意为之   Verilog是个大杂烩,这是有意而为之.   Verilog IEEE S ...

  10. Java实现 LeetCode 790 多米诺和托米诺平铺(递推)

    790. 多米诺和托米诺平铺 有两种形状的瓷砖:一种是 2x1 的多米诺形,另一种是形如 "L" 的托米诺形.两种形状都可以旋转. XX <- 多米诺 XX <- &q ...