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

如何在运行时指定泛型类型?

在运行时指定泛型类型可以通过Java的反射机制来实现。下面是一个示例代码:

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

public class GenericClass<T> {
    private Class<T> type;

    public GenericClass() {
        Type superClass = getClass().getGenericSuperclass();
        if (superClass instanceof ParameterizedType) {
            ParameterizedType parameterizedType = (ParameterizedType) superClass;
            Type[] typeArguments = parameterizedType.getActualTypeArguments();
            if (typeArguments.length > 0) {
                type = (Class<T>) typeArguments[0];
            }
        }
    }

    public Class<T> getType() {
        return type;
    }

    public static void main(String[] args) {
        GenericClass<String> genericClass = new GenericClass<>();
        System.out.println(genericClass.getType());  // 输出:class java.lang.String
    }
}

在上述示例中,通过getClass().getGenericSuperclass()获取到泛型类的父类类型,然后判断父类类型是否为ParameterizedType,如果是,则通过getActualTypeArguments()获取到泛型类型的实际参数类型。最后,通过强制类型转换将实际参数类型赋值给type变量。

这样,在运行时就可以通过getType()方法获取到指定泛型类型的Class对象,从而进行进一步的操作。

需要注意的是,由于Java的泛型擦除机制,运行时是无法获取到泛型的具体类型的,只能获取到泛型的边界类型。因此,在使用反射获取泛型类型时,通常是获取到泛型的边界类型,而不是具体的泛型类型参数。

推荐的腾讯云相关产品:无

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

相关·内容

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

泛型并不是C#语言一开始就带有的特性,而是在FCL2.0之后实现的新功能。基于泛型,我们得以将类型参数化,以便更大范围地进行代码复用。同时,它减少了泛型类及泛型方法中的转型,确保了类型安全。委托本身是一种引用类型,它保存的也是托管堆中对象的引用,只不过这个引用比较特殊,它是对方法的引用。事件本身也是委托,它是委托组,C#中提供了关键字event来对事件进行特别区分。一旦我们开始编写稍微复杂的C#代码,就肯定离不开泛型、委托和事件。本章将针对这三个方面进行说明。

02
领券