加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 无法选择参数化类型

发布时间:2020-12-14 05:56:18 所属栏目:Java 来源:网络整理
导读:我想创建一个休息来在服务器和客户端之间进行通信. 下面给出的构造函数: public class RestHelperI,R { public RestHelper(String url,I input,ClassR output){ ResponseEntityR responseEntity = restTemplate.exchange(url,HttpMethod.POST,requestEntity
我想创建一个休息来在服务器和客户端之间进行通信.

下面给出的构造函数:

public class RestHelper<I,R> {
    public RestHelper(String url,I input,Class<R> output){
        ResponseEntity<R> responseEntity = restTemplate.exchange(url,HttpMethod.POST,requestEntity,output );
    }
}

对于普通类型,我可以这样做:

RestHelper<User,Result> helper = new RestHelper<>(url,user,Result.class);

我如何传递泛型类型,如:

ResultContainData<Boolean>

以下代码无效:

ResultContainData<Boolean> result = new ResultContainData<>();
    RestHelper<User,ResultContainData<Boolean>> helper = new RestHelper<>(url,(Class<ResultContainData<Boolean>>) ((ParameterizedType) result.getClass().getGenericSuperclass()).getActualTypeArguments()[0]);

我收到了运行时错误:无法转换为ParameterizedType.

解决方法

您只能通过在子类定义中捕获它们来学习I和R的值 – 否则它们将在运行时被擦除.例如:
class MyStringRestHelper extends RestHelper<String,String> {

然后使用像TypeTools这样的东西你可以解析I和R的值:

Class<?>[] typeArgs = TypeResolver.resolveRawArguments(RestHelper.class,MyStringRestHelper.class);
Class<?> i = typeArgs[0];
Class<?> r = typeArgs[1];
assert i == r == String.class;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读