有这样的函数 public <T> T deserialize(byte[] bytes,Class<T> clazz)
返回值我想要Hashmap<String,Object>
,但clazz传HashMap.class并不匹配
有这样的函数 public <T> T deserialize(byte[] bytes,Class<T> clazz)
返回值我想要Hashmap<String,Object>
,但clazz传HashMap.class并不匹配
获取class信息时会把泛型信息抹掉,泛型本来也只是语法糖而已,参数T只能对T本身做约束(比如extends, super)。如果你确定deserialize可以处理Map类型,那么给一个Map.class,返回值Map就可以用,只是K/V的类型都是Object了,或者你自己实现一个反序列化器。
4 回答1.1k 阅读✓ 已解决
4 回答1.1k 阅读✓ 已解决
2 回答2.9k 阅读✓ 已解决
1 回答2.5k 阅读✓ 已解决
2 回答694 阅读✓ 已解决
2 回答1.7k 阅读
2 回答1.6k 阅读
参考一些框架的做法,通常是这样子
原理是,虽然没有List<String>.class这样的东西,但是如果是
这样子的话,是可以从StringList.class里拿到String这个泛型参数的。上面的例子也是创建了一个匿名内部类继承泛型类,然后就可以拿到泛型参数了。