I think the official documentation gives you the answer to this one (albeit in a fairly nonspecific way):
This method is the dynamic equivalent of the Java language instanceof operator.
I take that to mean that isInstance()
is primarily intended for use in code dealing with type reflection at runtime. In particular, I would say that it exists to handle cases where you might not know in advance the type(s) of class(es) that you want to check for membership of in advance (rare though those cases probably are).
For instance, you can use it to write a method that checks to see if two arbitrarily typed objects are assignment-compatible, like:
publicboolean areObjectsAssignable(Object left,Object right){return left.getClass().isInstance(right);}
In general, I'd say that using instanceof
should be preferred whenever you know the kind of class you want to check against in advance. In those very rare cases where you do not, use isInstance()
instead.
For instanceof
you need to know the exact class at compile time.
if(foo instanceofThisClassIKnowRightNow)...
For isInstance
the class is decided at run time. (late binding) e.g.
if(someObject.getClass().isInstance(foo))...