有这样的函数 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了,或者你自己实现一个反序列化器。
8 回答6.4k 阅读
1 回答4.2k 阅读✓ 已解决
3 回答2.3k 阅读✓ 已解决
2 回答2.8k 阅读✓ 已解决
2 回答3.2k 阅读
2 回答3.9k 阅读
3 回答1.7k 阅读✓ 已解决
参考一些框架的做法,通常是这样子
原理是,虽然没有List<String>.class这样的东西,但是如果是
这样子的话,是可以从StringList.class里拿到String这个泛型参数的。上面的例子也是创建了一个匿名内部类继承泛型类,然后就可以拿到泛型参数了。