扫码关注官方订阅号
闭关修行中......
参考一些框架的做法,通常是这样子
public <T> T deserialize(byte[] bytes,TypeReference<T> type)
HashMap<String, Person> map = deserialize(bytes,new TypeReference<HashMap<String, Person>(){});
原理是,虽然没有List<String>.class这样的东西,但是如果是
class StringList extends List<String>
这样子的话,是可以从StringList.class里拿到String这个泛型参数的。上面的例子也是创建了一个匿名内部类继承泛型类,然后就可以拿到泛型参数了。
获取class信息时会把泛型信息抹掉,泛型本来也只是语法糖而已,参数T只能对T本身做约束(比如extends, super)。如果你确定deserialize可以处理Map类型,那么给一个Map.class,返回值Map就可以用,只是K/V的类型都是Object了,或者你自己实现一个反序列化器。
实现接口啊。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
参考一些框架的做法,通常是这样子
原理是,虽然没有List<String>.class这样的东西,但是如果是
这样子的话,是可以从StringList.class里拿到String这个泛型参数的。上面的例子也是创建了一个匿名内部类继承泛型类,然后就可以拿到泛型参数了。
获取class信息时会把泛型信息抹掉,泛型本来也只是语法糖而已,参数T只能对T本身做约束(比如extends, super)。如果你确定deserialize可以处理Map类型,那么给一个Map.class,返回值Map就可以用,只是K/V的类型都是Object了,或者你自己实现一个反序列化器。
实现接口啊。