我有一个类,它有几个字段,这些字段是另一个类的子类。我想在顶级类中快速找到该子类的所有实例。
例如
public class TopClass {
private ClassIWant1 myVar1;
private ClassIWant2 myVar2;
private OtherJunk myVar3;
private Nested myVar4;
}
public class Nested {
private ClassIWant3 myVar11;
}
public class SuperClass {
}
public ClassIWant1 extends SuperClass {}
public ClassIWant2 extends SuperClass {}
public ClassIWant3 extends ClassIWant1 {}
如果我用TopClass
的实例运行该示例,我希望得到一个包含myVar1、myVar2和myVar11值的List。
我对如何使用反射手动完成这项工作有一个大致的想法,但我希望我不必重新发明轮子。有图书馆能做到这一点吗?
我熟悉ReflectUtils,但我不确定它是否能做到这一点。
如果我正确理解你的请求,你正在寻找这样的东西:
public class Test {
public static void main(String[] args) {
TopClass top = …; // initialise as appropriate
System.out.println(findFields(top, SuperClass.class));
}
private static <T> List<T> findFields(Object haystack, Class<T> needle) {
return findFields0(haystack, needle, new HashSet<Object>(), new ArrayList<T>());
}
private static <T> List<T> findFields0(Object haystack, Class<T> needle, Set<Object> visited, List<T> result) {
if (visited.contains(haystack)) return result; // we already searched this object
visited.add(haystack);
for (Field field : haystack.getClass().getFields()) {
field.setAccessible(true);
Object fieldValue = null;
try {
fieldValue = field.get(haystack);
} catch (IllegalAccessException e) {
// shouldn't happen
throw new RuntimeException(e);
}
if (needle.isAssignableFrom(field.getType())) {
result.add(needle.cast(fieldValue));
}
// recurse
findFields0(fieldValue, needle, visited, result);
}
return result;
}
}
这是通过使用声明的字段的静态类型来实现的。也就是说,如果您将字段声明为Object
,但它包含SuperClass
的实例或其子代之一,则找不到它。如果字段将它们设置为值,它也将返回null
s。我不知道这会对原始类型产生什么影响。
免责声明:代码在一个乐观的例子中进行了简短的测试,如果它导致您的计算机着火,我不承担任何责任。
您想要的是这个方法吗?