提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前言
由于Java的泛型是伪泛型(编译后类型消除),这就导致了泛型参数的反序列化问题。要处理该问题,根本就是解决泛型丢失问题。
在之前的项目中,序列化方法和反序列化方法不在一个接口中(读写服务分离),解决方法是在进行序列化写入时,将对象的Class也作为参数进行缓存,在读取时即可显式获取泛型类来进行反序列化。【这种方法就不详细说明】
若是读写在同接口或者同类中,即可使用反射获取泛型参数类来进行反序列化。
解决:使用反射获取泛型参数类
1.反射方法
反射方法如下(这里直接写在泛型接口内,建议写成工具类静态方法):
/**
* 反射获取第一个泛型参数类,用于处理因泛型消除无法指定泛型类型时的反序列化问题
* @param index 泛型参数次序
* @return 泛型参数类
*/
default Class<?> getGenericType(int index) {
Type[] genericInterfaces = this.getClass().getGenericInterfaces();
for (Type genericInterface : genericInterfaces) {
if (genericInterface instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) genericInterface;
Type[] typeArguments = parameterizedType.getActualTypeArguments();
if (typeArguments.length > index && typeArguments[index] instanceof Class) {
System.out.println("这是参数类:" + typeArguments[index]);
return (Class<?>) typeArguments[index];
}
}
}
return null;
}
耗时在纳秒级,本机测试为10w纳秒左右,即0.0001 秒,性能是完全可接受范围内;
2.反序列化
在知道泛型参数类后,反序列化就没啥问题了,使用序列化器指定类进行反序列化的方法。这里使用阿里的FastJson
default T getInfoFromCache(long compntId) {
String json = getRecorder().getCompntInfoFromCache(compntId); // 获取的序列化数据
return (T) JSON.parseObject(json, getGenericType(1));
}
End