首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过反射获取List <T>中的包含类型?

在Java中,通过反射获取List中的包含类型可以使用以下方法:

代码语言:java
复制
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.List;

public class ReflectionHelper {
    public static Class<?> getListType(List<?> list) {
        Type superclass = list.getClass().getGenericSuperclass();
        if (superclass instanceof ParameterizedType) {
            ParameterizedType parameterized = (ParameterizedType) superclass;
            Type[] typeArgs = parameterized.getActualTypeArguments();
            if (typeArgs.length > 0) {
                return (Class<?>) typeArgs[0];
            }
        }
        return Object.class;
    }
}

使用示例:

代码语言:java
复制
List<String> stringList = new ArrayList<>();
Class<?> listType = ReflectionHelper.getListType(stringList);
System.out.println("List type: " + listType.getName());

输出:

代码语言:txt
复制
List type: java.lang.String

这个方法使用了Java泛型的反射API,首先获取List的超类型,然后检查是否是一个参数化类型(ParameterizedType),如果是,则获取实际类型参数并返回第一个类型参数对应的类对象。如果不是参数化类型,或者类型参数为空,则返回Object.class作为默认类型。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • java反射技术的案例之泛型擦除

    正确理解泛型概念的首要前提是理解类型擦除(type erasure)。 Java中的泛型基本上都是在编译器这个层次来实现的。在生成的Java字节代码中是不包含泛型中的类型信息的。使用泛型的时候加上的类型参数,会被编译器在编译的时候去掉。这个过程就称为类型擦除。如在代码中定义的List<Object>和List<String>等类型,在编译之后都会变成List。JVM看到的只是List,而由泛型附加的类型信息对JVM来说是不可见的。Java编译器会在编译时尽可能的发现可能出错的地方,但是仍然无法避免在运行时刻出现类型转换异常的情况。类型擦除也是Java的泛型实现方式与C++模板机制实现方式之间的重要区别。

    01

    C++反射深入浅出 - 1. ponder 反射实现分析总篇

    给静态语言添加动态特性, 似乎是C++社区一件大家乐见其成的事情, 轮子也非常多, 我们不一一列举前辈们造的各种流派的轮子了, 主要还是结合我们框架用到的C++反射实现, 结合C++的新特性, 来系统的拆解目前框架中的反射实现. 另外代码最早脱胎于Ponder, 整体处理流程基本与原版一致, 所以相关的源码可以直接参考 ponder的原始代码 . 文章计划分分7篇: - [[1. c++反射深入浅出 - ponder 反射实现分析总篇]] - [[2. c++反射深入浅出 - property实现分析]] - [[3. c++反射深入浅出 - function实现分析]] - [[4. c++反射深入浅出 - 基于反射的Lua中间层实现]] - [[5. C++反射深入浅出 - 反射信息的自动生成]] - [[6. C++反射深入浅出 - 反射的其他应用]] - [[7. C++反射深入浅出 - c++20 concept 改造]]

    02
    领券