java.lang.Class cannot be cast to java.lang.reflect.ParameterizedType解决方案

背景

异常:java.lang.Class cannot be cast to java.lang.reflect.ParameterizedType 类型转换异常
主要是因为泛型使用不规范导致的错误,在MVP抽取中,我们需要懂得许多关联在一起的流程!
意思是Class类型不能转换成ParameterizedType类型,多出现于数据解析,泛型使用。先写的泛型,导致传回来的是个Object类型或List包裹的对象。

原因

使用Gson或Fastjson数据解析异常,这种写法在之前的版本中是没问题的,但是当你升级开发工具或者使用新版使用2022.2.1版本的Android Studio时,就会有类型转换异常的报错。
解决方法也很简单,我们换一种构造就可以啦。

解决方案

Gson数据解析异常:

 Type type = new TypeToken<SubListModel<LabelsBean>>() {
                    }.getType();
SubListModel<LabelsBean> tmp = new Gson().fromJson(json, type);

Gson解析可使用这种写法解决异常:

Type type = TypeToken.getParameterized(SubListModel.class, LabelsBean.class).getType();
SubListModel<LabelsBean> tmp = new Gson().fromJson(json, type);

Fastjson数据解析异常:

List<ResumeBean> list = JSON.parseObject(jsonArray.toString(), new TypeReference<List<ResumeBean>>() {
}.getType());

Fastjson解析可使用这种写法解决异常:

ParameterizedTypeImpl inner = new ParameterizedTypeImpl(new Type[]{ResumeBean.class}, null, List.class);
list = JSON.parseObject(jsonArray.toString(), inner);
public class SubListModel<T> implements Serializable {

    private String desc;
    private String lastDate;
    private float version;
    private List<T> positions;
    private List<T> list;
   
    public String getDesc() {
        return desc;
    }

    public void setDesc(String desc) {
        this.desc = desc;
    }

    public String getLastDate() {
        return lastDate;
    }

    public void setLastDate(String lastDate) {
        this.lastDate = lastDate;
    }

    public float getVersion() {
        return version;
    }

    public void setVersion(float version) {
        this.version = version;
    }

    public List<T> getPositions() {
        return positions;
    }

    public void setPositions(List<T> positions) {
        this.positions = positions;
    }

    public List<T> getList() {
        return list;
    }

    public void setList(List<T> list) {
        this.list = list;
    }
}

根本原因是使用反射获取对象,参数化类型转换导致的异常。

private Class<T> clazz;

//反射机制,获取对应的对象
@SuppressWarnings("unchecked")
public BaseDao() {//构造函数的作用:获取对应的实体类对象
     // this——表示当前类(UserDao)
     // this.getClass()——当前运行类的字节码(UserDao.class)
     // this.getClass().getGenericSuperclass()——当前运行类的父类(BaseDao<T>,以为User为例,那就是BaseDao<User>)
     Type type = this.getClass().getGenericSuperclass(); // generic 泛型
     // 强制转化“参数化类型”
     ParameterizedType parameterizedType = (ParameterizedType) type;
     // 参数化类型中可能有多个泛型参数
     Type[] types = parameterizedType.getActualTypeArguments();
     // 获取数据的第一个元素(User.class)
     clazz = (Class<T>) types[0]; 
}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 这个错误是因为在Java中,一个类不能被强制转换为ParameterizedType类型。通常是因为在使用反射时,尝试将一个Class对象转换为ParameterizedType对象,但是这个Class对象实际上不是一个ParameterizedType类型。要解决这个问题,需要检查代码中的反射使用,确保正确地使用了ParameterizedType类型。 ### 回答2: java.lang.Class无法强制转换为java.lang.reflect.ParameterizedType。 在Java中,java.lang.Class类表示运行时类的信息和属性,而java.lang.reflect.ParameterizedType接口表示带有参数的类型(泛型类型)。 这个错误是因为在尝试将Class对象强制转换为ParameterizedType对象时,类型转换发生了错误。 要解决这个问题,我们需要理解java.lang.reflect.ParameterizedType的使用情况。 ParameterizedType接口是Type接口的子接口,可以用于获取带有参数的类型信息,例如泛型类或泛型接口的类型参数信息。 如果我们想要获得一个类的泛型参数类型信息,我们可以使用java.lang.Class类中的getGenericSuperclass()方法或getGenericInterfaces()方法。 但是要注意,这些方法返回的类型是java.lang.reflect.Type,而不是java.lang.reflect.ParameterizedType。 如果我们想要将Type对象转换为ParameterizedType对象,我们需要进行类型检查和类型转换。 示例代码: import java.lang.reflect.ParameterizedType; import java.lang.reflect.Type; public class MyClass<T> { public MyClass() { Type type = getClass().getGenericSuperclass(); if (type instanceof ParameterizedType) { ParameterizedType parameterizedType = (ParameterizedType) type; // 在这里可以使用ParameterizedType对象来获取泛型参数类型信息 } } } 总结来说,java.lang.Class不能直接强制转换为java.lang.reflect.ParameterizedType,我们需要根据具体的使用情况进行类型检查和转换才能正确地获取泛型参数类型信息。 ### 回答3: java.lang.Class不能被转换为java.lang.reflect.ParameterizedType的原因是两者表示的是不同的类型信息。java.lang.Class用于表示类的信息,而java.lang.reflect.ParameterizedType用于表示泛型类型的信息。 当使用强制类型转换将一个对象转换为java.lang.reflect.ParameterizedType时,如果该对象实际上是java.lang.Class类型的对象,就会抛出ClassCastException。这是因为java.lang.Classjava.lang.reflect.ParameterizedType是不兼容的类型。 如果需要获取一个类中的泛型类型信息,应该使用java.lang.Class对象的getGenericSuperclass()方法来获取其父类的泛型类型信息,再通过强制类型转换获取到java.lang.reflect.ParameterizedType对象。 例如: ``` class MyGenericClass<T> { } class MyClass extends MyGenericClass<String> { } public static void main(String[] args) { MyClass myClass = new MyClass(); ParameterizedType parameterizedType = (ParameterizedType) myClass.getClass().getGenericSuperclass(); Type[] actualTypeArguments = parameterizedType.getActualTypeArguments(); Type actualTypeArgument = actualTypeArguments[0]; String genericType = actualTypeArgument.getTypeName(); System.out.println(genericType); } ``` 如果在强制类型转换时抛出了java.lang.ClassCastException,可以检查代码中的类型转换部分,并确保正确使用泛型。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jusenr

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值