获取泛型T的class,java语言的缺陷

// 这句代码获取不到泛型class
new Test<String>().getTClass();
  
// 这句代码可以获取到泛型class,因为是匿名内部类,本质也算继承了
new  Test<String>(){}.getTClass()

// 这句代码正常获取泛型class,因为在继承的情况下是可以的
new TestImpl().getTClass();





public class Test<T> {
    public Class<T> getTClass() {
        return (Class<T>) ((ParameterizedType) Test.this.getClass().getGenericSuperclass()).getActualTypeArguments()[0];
    }
}

public class TestImpl extends Test<String> {
}

总结:

这样new Test<String>()是获取不到泛型Class的,无解,我觉得是java的缺陷。

只有继承一下在获取才能获取到泛型Class,例如上面的TestImpl示例。

虽然new  Test<String>(){}.getTClass()可以获取到泛型,但是我们提供基础类,不能要求使用者必须用匿名内部类,使用者容易写错,所以不建议这样用。

有没有想起来Gson就是这样做的?因为Gson家喻户晓,所以大家都记住了。

new Gson().fromJson("json",new TypeToken<List<String>>(){}.getType());

如果想解决new Test<String>()获取不到泛型的问题,可以这样设计:

public class TestNew<T> {
    Class<T> clazz;

    public TestNew(Class<T> clazz) {
        this.clazz = clazz;
    }

    public Class<T> getTClass() {
        return clazz;
    }
}


Class<?> clazz3 = new TestNew<String>(String.class).getTClass(); Log.e("clazz 3", clazz3.toString());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java获取泛型T的Class通常有两种方式。 第一种方式是使用泛型类的getClass()方法来获取泛型T的Class信息。这种方式的前提是必须要创建泛型对象。具体实现方法如下: ``` public class GenericClass<T>{ public Class<T> getGenericClass() { Class<T> cls = (Class<T>) ((ParameterizedType)getClass().getGenericSuperclass()).getActualTypeArguments()[0]; return cls; } } public class Main { public static void main(String[] args) { GenericClass<String> gc = new GenericClass<String>(){}; System.out.println(gc.getGenericClass()); } } ``` 第二种方式是使用TypeReference类。这是由Jackson库提供的一个工具类,可以避免在运行时由于泛型擦除而导致的Class信息丢失的问题。具体实现方法如下: ``` public abstract class TypeReference<T> { private final Type type; protected TypeReference() { Type superClass = getClass().getGenericSuperclass(); if (superClass instanceof Class<?>) { throw new IllegalArgumentException("Internal error: TypeReference constructed without actual type information"); } type = ((ParameterizedType) superClass).getActualTypeArguments()[0]; } public Type getType() { return type; } } public class Main { public static void main(String[] args) { TypeReference<List<String>> typeReference = new TypeReference<List<String>>() {}; System.out.println(typeReference.getType()); } } ``` 无论是哪种方式,获取泛型T的Class都可以方便地进行类型检查和类型转换操作。但需要注意的是,在获取泛型T的Class时,必须要保证T已经被实例化。如果T没有被实例化,则获取Class信息可能不准确,无法保证正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值