泛型工作由编译器将不可见的转换插入到你的代码中。
例如,在将泛型添加到语言之前,您必须这样做。
List list = new ArrayList();
list.add("Foo");
list.add("Bar");
String str0 = (String) list.get(0);
String str1 = (String) list.get(1);
这很讨厌因为get()返回Object,所以你必须每一次都要从列表中获取一个String。
现在,List是通用的,get()返回T,所以你可以这样做。
List list = new ArrayList<>();
list.add("Foo");
list.add("Bar");
String str0 = list.get(0);
String str1 = list.get(1);
这里发生的是,编译器通过为您添加演员而将新版本转换为旧版本,但仍然存在。
然而,泛型的全部观点是,这些编译器生成的转换是保证安全的 – 即它们不能在运行时抛出ClassCastException。
在我看来,如果你使用泛型来隐藏不能保证安全的演员,只是因为它们很烦人,这是滥用该功能的。
无论是通用的方法,还是你做的
Boolean a = JsonPath.read(currentRule, "$.logged");
或者它返回Object,你做
Boolean a = (Boolean) JsonPath.read(currentRule, "$.logged");
这两个版本都可能在运行时抛出ClassCastException,所以我认为如果你被强制转换,至少你知道你正在做一些可能会失败的事情,那就更好了。
我认为一个通用方法的返回类型的参数类型参数T如果方法参数没有返回类型是不好的做法,除非返回的对象不能以一种损害类型安全性的方式使用。例如,
public static List emptyList()
在集合中可以(列表为空,因此不能包含错误类型的元素)。
在你的情况下,我认为read方法不应该是通用的,只能返回Object。