ParameterizedTypeReference的用法及场景
一,类的描述
超类型标记模式会捕获类信息中的泛型参数,以避免Java语言中类型擦除的限制。
关于这个类的描述,可以百度翻译一下。大概意思就是能确定返回对象的类型,而不受范型擦除的影响。
也可以参考这个文章的描述:
https://blog.csdn.net/m0_37607945/article/details/126598116
二,类的用法
场景:
当远程调用,返回的对象是范型确定的,则可以使用这个。避免了对返回对象的强转。
统一的返回类
@Data
@AllArgsConstructor
@NoArgsConstructor
public class ResponseShow<T> {
private String code;
private String message;
private T data;
}
返回data的一个类型
@Data
@AllArgsConstructor
@NoArgsConstructor
public class BackArray {
private String name;
}
方法比较:
package com.madorangecat.artmartxt.use.parameterized;
import org.springframework.core.ParameterizedTypeReference;
import org.springframework.http.HttpEntity;
import org.springframework.http.HttpMethod;
import org.springframework.http.ResponseEntity;
import org.springframework.web.client.RestTemplate;
import java.util.List;
public class ParameterizedTe {
/**
* 为什么要使用 ParameterizedTypeReference
* 举例:
* 远程调用接口,接口返回的对象为一个统一的封装对象,但对象内部包装但为List的一个对象
* ResponseShow<List<BackArray>>
*/
private static void parameterizedTe(){
HttpEntity<String> request = new HttpEntity<String>("");
// 使用直接请求方式:得到List<BackArray> backResult结果需要强转
RestTemplate restTemplate = new RestTemplate();
ResponseEntity<ResponseShow> listResponseEntity = restTemplate.postForEntity("url", request, ResponseShow.class, "");
ResponseShow body = listResponseEntity.getBody();
Object data = body.getData();
// 要强转
List<BackArray> backResult = (List<BackArray>) data;
// 使用ParameterizedTypeReference方式
ParameterizedTypeReference<ResponseShow<List<BackArray>>> backBodyType = new ParameterizedTypeReference<ResponseShow<List<BackArray>>>(){};
ResponseEntity<ResponseShow<List<BackArray>>> exchange = restTemplate.exchange("url", HttpMethod.POST, request, backBodyType);
ResponseShow<List<BackArray>> body1 = exchange.getBody();
// 非常完美
List<BackArray> data1 = body1.getData();
}
}