Used to search from a particular class up the inheritance hierarchy of extended classes and implemented interfaces.
The search starts with the initial class (provided in the constructor). It progresses up the inheritance chain, but skips java.lang.Object.
Once classes are exhausted, the inheritance hiearchy is searched. This is a breadth-first search, rooted in the interfaces implemented by the initial class at its super classes.
Once all interfaces are exhausted, java.lang.Object is returned (it is always returned last).
Two minor tweak to normal inheritance rules:
- Normally, the parent class of an object array is java.lang.Object, which is odd because Foo[] is assignable to Object[]. Thus, we tweak the search so that the effective super class of Foo[] is Object[].
- The "super class" of a primtive type is its wrapper type, with the exception of void, whose "super class" is left at its normal value (Object.class)
This class implements the {@link Iterable} interface, so it can be used directly in a for loop:
for (Class search : new InheritanceSearch(startClass)) { ... }
This class is not threadsafe.